@Enumerated(EnumType.STRING) -> Enum을 처리하기 위한 어노테이션 그런데 기본값은 EnumType.ORDINAL => 0, 1로 이루어진 숫자. 이러면 값이 중간에 삭제되거나 순서가 바뀌거나 하면 사고난다. 왜 쿼리Dsl을 쓰는가? 쿼리dsl을 쓰면 쿼리문 중간에 오타 발생률이 현저히 낮아진다. 컴파일 시점에 에러를 잡아내기 때문에 그렇다. JPQL이라면 런타임에서나 발견될만한 에러를 컴파일 단위에서 끌어내려서 먼저 발견. ---------------------- 컴파일 에러와 런타임 에러는 모두 프로그램 개발과 실행 과정에서 발생할 수 있는 문제입니다. 그러나 둘은 서로 다른 종류의 오류이며, 발생하는 시점과 원인도 다릅니다. 컴파일 에러는 소스 코드를 컴파일하는 과정에서 발..
Controller 단에서 @Controller @RequiredArgsConstructor public class ItemController { @GetMapping(value = "/admin/item/new") public String itemForm() { return "/item/itemForm"; } 리턴타입이 String이고, 문자열 리턴이 있으면, 이건 view로 인식한다. templates 가 기본 탐색 경로인데, templates에서 /item 폴더 안에 있는 itemForm을 의미한다. 반환이라기보다는 "파일경로"라고 생각하는 게 더 옳은 판단. 만약 문자열 자체를 반환하고 싶다면? view 이름이 아닌... 그럴 때 메서드 위에 @ResponseBody를 붙인다. -> view이름으..

시큐리티 public class CustomAuthenticationEntryPoint implements AuthenticationEntryPoint { @Override public void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authException) throws IOException, ServletException { response.sendError(HttpServletResponse.SC_UNAUTHORIZED, "Unauthorized"); // 인증에 대한 접근 권한을 판단. // 이제 이걸 쓸 거다. } } - 웹에서 들어온 요청을 가지고 인증 또는 인가에 관련된..

https://school.programmers.co.kr/learn/courses/30/lessons/181839 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 문제 설명 1부터 6까지 숫자가 적힌 주사위가 두 개 있습니다. 두 주사위를 굴렸을 때 나온 숫자를 각각 a, b라고 했을 때 얻는 점수는 다음과 같습니다. a와 b가 모두 홀수라면 a2 + b2 점을 얻습니다. a와 b 중 하나만 홀수라면 2 × (a + b) 점을 얻습니다. a와 b 모두 홀수가 아니라면 |a - b| 점을 얻습니다. 두 정수 a와 b가 매개변수로 주어질 때, 얻는 점수를 ..

https://school.programmers.co.kr/learn/courses/30/lessons/181919 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 문제 설명 모든 자연수 x에 대해서 현재 값이 x이면 x가 짝수일 때는 2로 나누고, x가 홀수일 때는 3 * x + 1로 바꾸는 계산을 계속해서 반복하면 언젠가는 반드시 x가 1이 되는지 묻는 문제를 콜라츠 문제라고 부릅니다. 그리고 위 과정에서 거쳐간 모든 수를 기록한 수열을 콜라츠 수열이라고 부릅니다. 계산 결과 1,000 보다 작거나 같은 수에 대해서는 전부 언젠가 1에 도달한다는 것이 ..
값 타입 엔티티(Entity)에 속하지 않고, 단순히 엔티티의 속성으로 사용되는 객체 JPA에서 임베디드(Embedded) 타입도 값 타입의 한 종류 임베디드 타입 여러 개의 속성을 하나로 묶어 하나의 객체로 표현할 수 있도록 하는 것 ex. 주소(Address) 객체를 임베디드 타입으로 사용 많이 함. 이러한 경우 주소는 엔티티가 아니라, 엔티티의 속성으로 존재 + 해당 엔티티와 생명주기를 공유한다. 임베디드 타입 사용 시 코드의 재사용성과 가독성 향상. 복합적 데이터를 간단하게 모델링할 수 있음. 필요한 경우 임베디드 타입을 재사용하여 중복을 피할 수 있음. JPA에서 임베디드 타입 사용하기 임베디드 타입으로 사용할 클래스를 정의. 해당 클래스에 @Embeddable 어노테이션을 붙여, JPA에게 이..
DDL Auto 옵션 (총 5가지) none: 사용하지 않음 create: 기존 테이블 삭제 후 테이블 생성 create-drop: 기존 테이블삭제 후 테이블 생성. 종료 시점에 테이블 삭제 update: 변경된 스키마 적용 validate; 엔티티와 테이블 정상 매핑 확인 - update 옵션에서 컬럼 삭제는 엄청난 문제를 발생시킬 수 있기 때문에 컬럼 추가만 반영된다. - 개발 초기에는 create 또는 update 옵션을 이용해시 익숙해지는 데 집중하고 추후에 validate 옵션을 설정 해 주는 것이 좋다. - 스테이징, 운영환경에서는 절대로 create, create-drop. update를 사용하면 안 된다. - 스테이징과 운영 서버에서는 테이블 생성 및 컬럼 추가, 삭제, 변경은 데이터베이스..

JPA(Java Persistence API) : 자바 ORM 기술에 대한 API 표준 ORM(Object Relational Mapping) : 객체와 관계데이터베이스를 매핑 CRUD – INSERT, UPDATE, SELECT, DELETE 그리고, 데이터베이스는 관계형 데이터베이스를 사용한다. 그런데 자바는? 객체지향 언어이므로 객체와 관계형 데이터베이스 간에 필연적으로 불일치가 발생하고, 이것은 큰 문제가 된다. => 따라서 객체지향과 관계형 데이터베이스 간의 패러다임이 불일치 하기 때문에, ORM이 등장. # JPA는 인터페이스 # 대표적인 구현체 Hibernate, EclipseLink, DataNucleus, OpenJpa, TopLink 등 보통 Hibernate 로 개발. JPA의 장점 ..