BackEnd (47) 썸네일형 리스트형 EXPLAIN 사용 방법 데이터베이스 성능 최적화를 위해 EXPLAIN을 사용하여 SQL 실행 계획을 분석하는 방법을 정리하고자 합니다.1. EXPLAIN 기본 개념 EXPLAIN은 SQL 실행 계획을 분석하고 최적화할 수 있도록 도와주는 명령어입니다.EXPLAIN SELECT * FROM 테이블명 WHERE 조건; 또는 실행 시간을 포함한 상세한 분석을 원하면 ANALYZE를 사용할 수 있습니다.(ANALYZE 사용 가능 버전은 MySQL 8.0+, MariaDB 10.5+ 입니다.😢)EXPLAIN ANALYZE SELECT * FROM 테이블명 WHERE 조건; 2. EXPLAIN 결과 컬럼 설명 EXPLAIN 쿼리를 수행하면 아래와 같은 컬럼들을 조회할 수 있습니다.컬럼명 설명id실행 단계 (조인 시 여러 개의 ID가 존.. QueryDSL에서 join()과 innerJoin() 차이 QueryDSL 사용 중, 잘못 알고 있던 내용이 있었다. 아래와 같은 쿼리를 사용했다고 가정한다.-- JOIN SELECT * FROM AJOIN B ON A.id = B.a_id;-- INNER JOINSELECT * FROM AINNER JOIN B ON A.id = B.a_id; 일반적으로 SQL 문 작성 시, JOIN을 사용하면 기본적으로 INNER JOIN을 사용한다고 알고 있었다.하지만 QueryDSL에서는 join()과 innerJoin()이 따로 존재한다. ✔️join()조인할 대상이 @OneToMany 혹은 @ManyToMany 관계일 때 사용JPQL에서는 기본적으로 LEFT JOIN으로 처리됨결과가 없는 경우에도 기준 테이블(A)의 데이터는 유지됨.QMember member = QM.. Notepad로 UTF-8 BOM 문제 해결하기 UTF-8 인코딩으로 저장된 스크립트 파일에서 $'\357\273\277cd와 같은 오류 메시지가 발생한 적이 있나요?스크립트 파일을 작성하여 실행 중에... 이런 오류가 있어서 하루를 날려버렸습니다.언제쯤 삽질은 안하게 될까요? 하하하 이 오류는 주로 파일의 시작 부분에 포함된 BOM(Byte Order Mark) 때문입니다. BOM은 파일의 인코딩 방식을 표시하는 특수 문자로, 쉘 스크립트와 같은 텍스트 파일에서 문제가 발생할 수 있습니다. 문제의 원인 BOM(Byte Order Mark)은 파일의 시작 부분에 붙어 인코딩 방식을 표시합니다. UTF-8로 저장된 파일이 BOM을 포함하고 있으면 쉘에서 BOM 문자를 불필요한 문자로 인식하여 오류가 발생할 수 있습니다. 이 경우, 스크립트가 올바르게 실.. 인증(Authentication)과 인가(Authorization)의 차이점 인증(Authentication)과 인가(Authorization)는 보안 시스템에서 중요한 두 개념으로, 둘 다 보안과 관련된 용어이지만 그 의미와 목적이 다릅니다. 둘 다 Auth~로 시작을 하다 보니 너무 헷갈리는데, 한자로 보면 좀 이해가 갑니다.인증 (인정할 인 認, 증명할 증 證): 어떤 사람이나 사물이 진짜임을 인정하고 증명하는 것. 인가 (인정할 인 認, 허락할 가 可): 어떤 행위나 요청에 대해 인정하고 허락하는 것. 부끄럽지만 인증과 인가의 차이를 명확하게 정의할 수 없었지만, OAuth 인증 프로토콜을 공부하다가 끄적여봅니다-! 🔐인증 (Authentication)🔓 정의인증은 사용자가 누구인지를 확인하는 과정입니다. 즉, 사용자의 신원을 확인하는 단계입니다. 목적시스템은 사용자.. [모던자바인액션] Stream 스트림 활용 스트림 활용 명시적 반복 대신 filter와 collect 연산을 지원하는 스트림 API를 이용해서 데이터 컬렉션 반복을 내부적으로 처리할 수 있다. @Test void streamSample() { List nameList = new ArrayList(); nameList.add("럭스"); nameList.add("룰루"); nameList.add("애쉬"); nameList.add("트린다미어"); // 외부 반복 List longNameList = new ArrayList(); for (String s : nameList) { if(s.length() > 5) { longNameList.add(s); } } // 내부 반복 List longNameStreamList = nameList.stream.. [모던자바인액션] Stream 스트림 스트림 (Stream) 컬렉션(collections)로 데이터를 그룹화하고 처리할 수 있다. 컬렉션은 모든 자바 어플리케이션에서 처리하고, 대부분의 프로그래밍 작업에 사용되기 때문에 중요하다.하지만 아직 완벽한 컬렉션 연산을 지원하려면 부족하다. 스트림이란 무엇인가 스트림도 자바 8 API에 새로 추가된 기능이다. 데이터를 처리하는 코드를 질의로 표현하여 선언형으로 컬렉션 데이터를 처리할 수 있다. 스트림을 사용하면 멀티스레드 코드를 구현하지 않아도 데이터를 병렬로 처리할 수 있다. @Test @DisplayName("요리 클래스 정렬하기") void sortExample() { List menuList = new ArrayList(); menuList.add(new Dish(100,"닭가슴살")); m.. [모던자바인액션] 람다 (Lambda) 람다표현식은 익명클래스처럼 이름이 없는 함수이다. 메서드를 인수로 전달할 수 있는 친구입니다. 람다 용어 자체는 미적분학 학계에서 유래되었답니다. 오늘은 람다 람다하는 그 람다에 대해서 정리해보려고 합니다. 모던자바인액션 책 사랑해요 1. 람다란 무엇인가? 람다 표현식: 메서드로 전달할 수 있는 익명 함수를 단순화한 것. 람다 특징 1) 익명이다. 메서드와 다르게 이름이 없다. 2) 함수이다. 특정 클래스에 종속되지 않는다. 그래서 함수라고도 불림. 하지만 메서드의 특징 또한 가짐. 3) 전달이 가능하다. 람다 표현식을 메서드 인수로 전달하거나 변수로 저장 가능. 4) 간결하다. 익명 클래스처럼 중복되거나 클래스 생성을 위한 코드를 구현할 필요 없음. cf) 메서드의 특징은? - 파라미터 리스트, 바디,.. 함수형 인터페이스 (Functional Interface) Java에서 함수형 인터페이스는 단일 추상 메서드(Single Abstract Method, SAM)를 가진 인터페이스다. Java 8 이상에서는 람다 표현식 및 함수형 인터페이스를 지원한다. 함수형 인터페이스의 추상 메서드 시그니처는 람다 표현식과 연관이 있다. (추상 메서드 시그니처는 해당 함수형 인터페이스가 나타내는 함수의 형태를 결정하는 것) java.util.function 패키지에는 다양한 함수형 인터페이스가 포함되어 있음. Consumer 인터페이스의 추상 메서드는 다음과 같다. @FunctionalInterface public interface Consumer { void accept(T t); } 여기서 accept가 추상 메서드이다. 이 메서드는 하나의 매개변수를 받고 반환값이 없츰. .. 이전 1 2 3 4 ··· 6 다음 목록 더보기