본문 바로가기

전체 글46

HTTP HTTP(HyperText Transfer Protocol) 텍스트 기반의 통신 규약으로 인터넷에서 데이터를 주고 받을 수 있는 프로토콜 HTML, TEXT IMAGE, 음성, 영상, 파일 JSON, XML 거의 모든 형태의 데이터 전송 가능 서버간에 데이터를 주고 받을 때도 대부분 HTTP 사용 특징 1) 클라이언트 서버 구조 Request, Response 구조 클라이언트는 서버에 요청을 보내고, 응답을 대기 서버가 요청에 대한 결과를 만들어서 응답 2) 무상태 프로토콜 서버가 클라이언트의 상태를 보존하지 않음 장점 : 서버 확장성이 높음(응답 서버를 쉽게 바꿀 수 있음) 단점 : 클라이언트가 추가 데이터 전송 Stateful, Stateless의 차이는 서버가 클라이언트의 상태 보존 유무 3) 비연.. 2024. 2. 5.
인터넷 네트워크 IP(Internet Protocol) : 인터넷 프로토콜(IP, Internet Protocol)은 송신 호스트와 수신 호스트가 패킷 교환 네트워크에서 정보를 주고받는 데 사용하는 정보의 규약이며, OSI 네트워크 계층에서 호스트의 주소지정과 패킷 분할 및 조립 기능을 담당 역할 지정한 UP 주소에 데이터 전달 패킷(Packet)이라는 통신 단위로 데이터 전달 한계 비연결성 : 패킷을 받을 대상이 없거나 서비스 불능 상태여도 패킷 전송 비신뢰성 : 패킷 소실, 패킷 전달 순서 문제 발생(보낸 순서대로 도착한다는 보장이 없음) 프로그램 구분 : 동일한 IP를 사용하는 서버에서 통신하는 애플리케이션이 둘 이상인 경우 구분 불가 TCP(전송 제어 프로토콜) : 인터넷을 통해 디바이스에서 웹 서버로 데이터를 .. 2024. 2. 4.
벌크연산(Bulk Operation) 기존연산 ex) 모든 직원들 연봉 30% 인상 em.find() 메서드를 통해 모든 직원을 리스트로 조회 직원 엔티티의 연봉을 30% 증가 Commit 시점에 변경감지(Dirty Checking)가 일어나며 update 쿼리 실행 만약 리스트로 조회된 결과가 몇십만, 몇백만개라면 성능의 문제 발생 따라서 벌크연산이 필요 벌크연산(Bulk Operation) 쿼리 한 번으로 여러 테이블 로우 변경(엔티티) executeUpdate() 메서드를 통해 벌크연산 수행 executeUpdate()의 결과는 영향받은 엔티티의 수 UPDATE, DELETE 지원 String qlString = "update Product p " + "set p.price = p.price * 1.1" + "where p.stockA.. 2024. 1. 17.
Named 쿼리 Named 쿼리 미리 정의해서 이름을 부여해두고 사용하는 SQL 미리 정의하기 때문에 정적 쿼리 어노테이션이나 XML에 정의 @Entity @NamedQuery( // Named 쿼리 사용 name = "Member.findByUsername", query = "select m from Member m where m.username = :username") public class Member{ ... } ... public class JpaMain { public static void main(String[] args) { List resultList = em.createNamedQuery("Member.findByUsername", Member.class) .setParameter("username",.. 2024. 1. 17.
페치조인 페치조인(fetch join) JPQL에서 성능 최적화를 위해 제공하는 기능으로 SQL 조인 종류가 아님 연관된 엔티티나 컬렉션을 SQL 한 번에 함께 조회하는 기능 join fetch 명령어 사용 N+1 문제 Team teamA = new Team(); teamA.setName("팀A"); em.persist(teamA); Team teamB = new Team(); teamB.setName("팀B"); em.persist(teamB); Member member1 = new Member(); member1.setUsername("회원1"); member1.setTeam(teamA); em.persist(member1); Member member2 = new Member(); member2.setUser.. 2024. 1. 15.
값 타입 컬렉션 값 타입 컬렉션 값 타입을 하나 이상 저장할 때 사용 @ElementCollection, @CollectionTable 주요 특징 데이터베이스는 컬렉션을 같은 테이블에 저장 불가 -> 별도의 테이블이 필요 @Entity public class Member { @Id @GeneratedValue @Column(name = "MEMBER_ID") private Long id; @Column(name = "USERNAME") private String userName; @Embedded private Address homeAddress; // 값 타입 컬렉션 사용 @ElementCollection // FAVORITE_FOOD 테이블 정의 @CollectionTable(name = "FAVORITE_FOOD".. 2024. 1. 2.