본문 바로가기

BackEnd

(42)
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)🔓 정의인증은 사용자가 누구인지를 확인하는 과정입니다. 즉, 사용자의 신원을 확인하는 단계입니다. 목적시스템은 사용자..
함수형 인터페이스 (Functional Interface) Java에서 함수형 인터페이스는 단일 추상 메서드(Single Abstract Method, SAM)를 가진 인터페이스다. Java 8 이상에서는 람다 표현식 및 함수형 인터페이스를 지원한다. 함수형 인터페이스의 추상 메서드 시그니처는 람다 표현식과 연관이 있다. (추상 메서드 시그니처는 해당 함수형 인터페이스가 나타내는 함수의 형태를 결정하는 것) java.util.function 패키지에는 다양한 함수형 인터페이스가 포함되어 있음. Consumer 인터페이스의 추상 메서드는 다음과 같다. @FunctionalInterface public interface Consumer { void accept(T t); } 여기서 accept가 추상 메서드이다. 이 메서드는 하나의 매개변수를 받고 반환값이 없츰. ..
NonNull 사랑...사...사...랑... 그냥 좋아합니다. @NonNull은 사용자에게 null 체크 잘하십쇼 하고 알려줄 수 있는 어노테이션입니다 보통 사용할 수 있는 용도는 아래와 같습니다 Record component / 함수의 파라미터 / 생성자의 파라미터 요렇게 쓸 수 있습니다 public void doSomething(@NonNull String input) { // input은 null일 수 없음 // 여기서 안전하게 input을 사용할 수 있음!! } @NonNull을 안 쓰면 아래와 같이 했겠쥬? 사실 씨쟁이는 아래의 코드가 더 익숙하지만 😒 파라미터만 보면 if 문 만들어야 직성이 풀리는 편. public void doSomething(String input) { // input은 null이면 아니된다.. if( input == null ) {..
Intellij) JUnit5 설정할 사람 괌 요즘 일하면서 내가 제일 신경 쓰고 있는 것은 히스토리를 잘 남기는 것이다 모든 일은 누구나 할 수 있다는 것을 깨달았지만 코드마다 있는 사연은... 그 사람밖에 알 수가 없다는 것이다 🥹 왜 그렇게 생각하게 됐냐구요? 저도 그러고 싶지 않았습니다 그래서!! 테스트 코드를 여느때와 다름없이 작성하던 중... 기존에는 JUnit4 버전으로 사용하고 있었는데 다른 담당자가 테스트 코드 실행 시 빠르게 내용을 파악하시면 좋겠다고 생각이 들었다 결론부터 먼저 말하자면.. 테스트 코드를 실행했을 때 아 이런 테스트~를 쉽게 파악하길 원했다 그러기 위해서는 @DisplayName 같은 어노테이션 사용이 필요했고, 이를 사용하기 위해서는 JUnit 버전을 업그레이드 해야했다 1. JUnit5 의존성 추가 (1) bu..
Error) java: class, interface, or enum expected 해결 File-Settings-Editor-File Encodings Path 추가해서 에러가 난 디렉터리 또는 파일에 Encoding 설정을 해주면 됩니다 그래도 안된다면 새로 파일을 추가하고 코드를 복붙하는게 가장 빠릅니다. 저 같은 경우에는 로그나 코드에 인코딩 설정을 바꿨는데, 저런 에러가 생기더라구요 한글이 깨지는 현상이 생겨서 해결하려다가 에러를 만나게 된; 원인은 BOM(Byte Order Mark) 이라는 것이 생겨서 그렇습니다. 유니코드의 인코딩 방식에는은 빅엔디안(BE)과 리틀엔디안(LE)이 있습니다. 둘의 차이는 바이트를 읽는 순서의 차이인데, 이 것을 파일에 명시하기 위해 앞에 인코딩별 BOM 값을 살짝 넣어 놓습니다.