본문 바로가기

Java

(29)
[Java] 자바 HTTP통신 (HttpURLConnection) [ URL 설정 ]요청을 보낼 url객체 생성하고,  openConnection() 메소드 호출하면해당 URL에 대한 연결 객체를 반환한다. 이 반환된 객체를 HttpURLConnection 로 캐스팅하면  네트워크 연결 준비 완료.URL url = new URL("https://example.com");HttpURLConnection con = (HttpURLConnection) url.openConnection(); // 연결 열기* 실제 네트워크 연결은 getInputStream(), getOutputStream() 메서드 호출 시점.  [ 네트워크 옵션 ] (메서드, 헤더, 입출력 사용 설정)con.setRequestMethod("POST"); // "GET", "PUT", "DELETE..
[Java] 자바 HTTP 통신_GET요청 (RestTemplate) * RestTemplateSpring에서 제공하는 동기식 HTTP 클라이언트 (요청에 대한 응답을 수신할때까지 대기) - GET, POST, PUT, DELETE, HEAD, OPTIONS 등의 HTTP 메서드 지원.  (GET요청)- getForObject 메소드 RestTemplate request = new RestTemplate(); String url = "http://example:8080"; String response = restTemplate.getForObject(url, String.class); System.out.println("Response: " + response);=> url에 get요청을 보내면 지정된 타입의 객체로 응답 반환. (위의 예시에서는 St..
[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 해줬더니 해결!