Java (43) 썸네일형 리스트형 [JPA] findBy~ 일부 필드값만 가져오기 (JPQL, 네이티브쿼리) / (+ 오류) [ User 엔티티 클래스 ]> userId, userName, userEmail, userPwd 네개의 필드를 가지고 있다.import javax.persistence.Entity;import javax.persistence.Id;import javax.persistence.GeneratedValue;import javax.persistence.GenerationType;import javax.persistence.Column;import javax.persistence.Table;import lombok.Getter;import lombok.Setter;import lombok.NoArgsConstructor;import lombok.AllArgsConstructor;@Getter@Setter@NoA.. [JPA] JPA_existBy~ / Querydsl 성능비교 (+ fetchOne(), fetchFirst()) * 아이디 중복확인 체크로직 두가지 방법으로 실행속도 비교1. JPA Repository 메소드 사용2. QueryDSL 사용 1. JPA Repository _ existBy~ 메소드 * UserRepositorypublic interface UserRepository extends JpaRepository { boolean existsByUserIdAndCode(String userId, String code);} * UserService// 아이디 중복확인 체크 로직// param: String userId, String codeif(UserRepository.existsByUserIdAndCode(userId, code)){ throw new CustomExc.. [JPA] List<Entity> 비교 * 자바 List 비교 참고https://phyho.tistory.com/317 [JS] 배열값 비교 (include, '===') / Java_List 비교* 배열요소 비교 ( include ) const arr = [1, 2, 3, 4, 5];console.log(arr.includes(2)); // true * includes() 함수는 내부적으로 '===' 연산자를 사용하여 요소를 비교하기 때문에 다른 타입은 비교 불가능.const mixedArr =phyho.tistory.com [ Entity 클래스 ]@Entity@Getter@Setter@Builder@NoArgsConstructor@AllArgsConstructorpublic class Entity { private String id.. [JPA] findById, existsById, getById * findById(id)id에 해당하는 엔티티를 반환 (Optional)해당하는 엔티티가 없는경우 'Optional.empty()' 반환 * existsById(id)id에 해당하는 엔티티의 존재여부 반환 (boolean) 해당하는 엔티티가 있다면 첫번재 결과에서 바로 true를 리턴. (아래처럼 최적화된 select 쿼리 실행) Hibernate: select id from table where id=? limit 1 * getById(id)id에 해당하는 엔티티를 반환 (엔티티가 반드시 존재한다고 가정 )해당하는 엔티티가 없는 경우 'javax.persistence.EntityNotFoundException' 예외. [JPA] Querydsl 벌크삭제 Querydsl 을 사용해서 벌크삭제를 해봤다. 아래와 같은 세개의 엔티티 클래스가 있다면, ' User ' , ' Order ', ' Post '=> 각 User는 여러 Order를 가질 수 있고, 또한 여러 Post를 가질 수 있음. User 엔티티 삭제로직을 처음에는 아래처럼 만들었다.(User의 pk가 'userId'와 'userCode'라고 가정. 세세한 로직은 생략.)if (!deleteList.isEmpty()) { List delList = new ArrayList(); for (Map del : deleteList) { String userId = String.valueOf(del.get("userId")); String userCode = Stri.. [오류 / IntelliJ] error: (패키지명) does not exist error: (패키지경로) does not exist import (경로); Cannot resolve symbol ~ 패키지명을 한번 변경했다고 계속 위와같은 오류가 났다. import문 확인해봐도 경로에 문제는 없었다. Rebuild Project 해줬더니 해결! [오류] HttpMessageNotReadableException : Required request body is missing DefaultHandlerExceptionResolver : Resolved [org.springframework.http.converter.HttpMessageNotReadableException: Required request body is missing: public org.springframework.http.ResponseEntity ... 경로...Controller.deleteEntity(java.util.Map)] 프론트 쪽에서 아래의 함수로 서버에 요청을 보내고 export const deleteEntityApi = async (param) => { const response = await api.delete(`ent/${param}`); return response.data; } ** .. [오류 / JPA] dentifier of (엔티티) an instance of Entity was altered from A to B identifier of an instance of (Entity) was altered[dispatcherServlet] : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed: org.springframework.orm.jpa.JpaSystemException: identifier of an instance of (엔티티) was altered from ( A ) to ( B ) with root cause 본질적으로는 JPA 영속성 관련 문제인데, (JPA에서는 객체들을 우선 영속성 컨텍스트에 등록(flush) 후.. 이전 1 2 3 4 5 6 다음