본문 바로가기

IT

(84)
JPA 공부 - 3 2021/01/21 - [IT/데이터베이스] - JPA 공부 - 2 3. 영속성 관리 JPA가 제공하는 기능은 크게 두 가지가 있음 엔티티와 테이블을 매핑하는 설계 부분 매핑한 엔티티를 실제로 사용하는 부분 엔티티 매니저는 엔티티를 저장 / 수정 / 삭제 / 조회하는 등 엔티티와 관련된 일을 한다. 엔티티 매니저는 엔티티를 저장하는 가상의 데이터베이스로 생각하면 된다. 3.1 엔티티 매니저 팩토리와 엔티티 매니저 데이터베이스를 하나만 사용하는 애플리케이션은 일반적으로 EntityManagerFactory 를 하나만 생성하고, 엔티티 매니저 팩토리에서 엔티티 매니저를 생성하여 사용한다. 엔티티 매니저 팩토리를 생성하는 비용은 상당히 크고 팩토리에서 엔티티 매니저를 생성하는 비용은 적다. 엔티티 매니저 팩토..
intellij Unexpected error (103) returned by AddToSystemClassLoaderSearch 문제 윈도우 환경 Intellij로 개발을 하다 보면 디버깅 시에 아래와 같은 에러를 마주할 수 있다. 경로명에 한글이 들어가서 이런 이슈가 들어간다고 추측(?) 하고 있다. 해결방법은 (2020.3.2 커뮤니티 버전 기준) 1. File -> Settings... 2. Build, Execution, Deployment -> Debugger -> Async Stack Traces 에서 Instrumenting agent 체크를 풀어주면 된다. 깔----끔
JPA 공부 - 5 2021/01/29 - [IT/데이터베이스] - JPA 공부 - 4 5. 연관관계 매핑 기초 객체는 참조(주소)를 사용해서 관계를 맺고 테이블은 외래 키를 사용해서 관계를 맺는다. 객체의 참조와 테이블의 외래 키를 매핑해보자 방향 예를 들어 회원과 팀이 있을 때 둘 중 한쪽만 참조하는 것을 단방향 관계라고 한다. 반대로 양쪽 모두 서로 참조하는 것을 양방향 관계라 한다. 방향은 객체관계에서만 존재하고 테이블은 항상 양방향이다. 다중성 [다대일(N:1)], [일대다(1:N)], [일대일(1:1)], [다대다(N:M)] 다중성이 있다. 회원과 팀 관계에서 여러 회원은 한 팀에 속하므로 회원과 팀은 다대일 관계다. 반대로 한 팀에 여러 회원이 소속될 수 있으므로 팀과 회원은 일대다 관계다. 연관관계의 주인 객..
JPA 공부 - 4 2021/02/25 - [IT/데이터베이스] - JPA 공부 - 3 4. 엔티티 매핑 JPA를 사용하는 데 가장 주우요한 일은 엔티티와 테이블을 정확히 매핑하는 것이다. JPA는 다양한 매핑 어노테이션을 지원하는데 크게 4가지로 분류할 수 있다. 객체와 테이블 매핑 기본 키 매핑 필드와 컬럼 매핑 연관관계 매핑 4.1 @Entity JPA를 사용해 테이블과 매핑할 클래스는 @Entity 어노테이션을 필수로 부여야 한다. @Entity가 붙은 클래스는 JPA가 관리하는 것으로, 엔티티라 부른다. 주의사항 기본 생서자 필수 final 클래스, enum, interface, inner 클래스에는 사용할 수 없다. 저장할 필드에 final 을 사용하면 안 된다. 4.2 @Table @Table은 엔티티와 매핑할..
git repo user 변경 최근 100일 커밋 프로젝트를 진행하고 있다. 그래서 매일매일 열심히 커밋을 하고 푸시를 하고 있다. 그런데 이전에는 집에서 윈도우 PC를 가지고 커밋을 진행했었다. 문제는 최근 이사를 하면서 책상을 버리는 바람에 모니터와 기타 잡동사니들을 올릴만한 책상이 없었고 그냥 회사 노트북으로 업무도 하고 100일 잔디 심기도 진행을 했다. 그런데 오늘 보니 나는 분명 커밋을 했는데 잔디가 아니라 시멘트가 눈에 보였다. 그래서 커밋 히스토리를 뒤져봤고 분명 아래처럼 커밋도 제대로 했었다. 그래서 이 억울함을 친구들에게 말하니 그 친구가 친절하게 뼈를 때려주었다.... Git repo 변경 방법 참고로 계정은 회사 : demo.lim 개인 : vljh246v 이다 우선 아래 명령어와 같이 저장된 이름과 이름을 확인..
JPA 공부 - 2 2021/01/18 - [IT/데이터베이스] - JPA 공부 - 1 JPA 공부 - 1 2021/01/17 - [IT/데이터베이스] - JPA 공부 - 0 1. JAP 소개 1.1 SQL을 직접 다룰 때 발생하는 문제점 관계형 데이터베이스는 가장 대중적이고 신뢰할 만한 안전한 저장소 JDBC API 를 사용해서 SQL을 데이터 demoversion.tistory.com 2. JPA 시작 2.1 이클립스 설치와 프로젝트 불러오기 예제 경로 https://github.com/holyeye/jpabook 2.2 H2 데이터베이스 설치 다운로드 경로 : https://www.h2database.com/ 2.3 라이브러리와 프로젝트 구조 위 3개 챕터는 설정이라 넘어감 2.4 객체 매핑 시작 회원 테이블 CREA..
JPA 공부 - 1 2021/01/17 - [IT/데이터베이스] - JPA 공부 - 0 1. JAP 소개 1.1 SQL을 직접 다룰 때 발생하는 문제점 관계형 데이터베이스는 가장 대중적이고 신뢰할 만한 안전한 저장소 JDBC API 를 사용해서 SQL을 데이터베이스에 전달 1.1.1 반복 예를들어 회원 관리 기능을 개발해 보자 회원 관리용 객체 생성 및 회원용 DAO 생성 // 회원 객체 public class Member { private String memberId; private String name; ... } // 회원용 DAO public class MemberDAO { public Member find (String memberId) {...} } 회원 조회용 기능 개발 회원 조회용 SQL 작성 SELECT M..
JPA 공부 - 0 2021/01/18 - [IT/데이터베이스] - JPA 공부 - 1 2021/01/21 - [IT/데이터베이스] - JPA 공부 - 2 2021/02/25 - [IT/데이터베이스] - JPA 공부 - 3 2021/01/29 - [IT/데이터베이스] - JPA 공부 - 4 2021/02/07 - [IT/데이터베이스] - JPA 공부 - 5 2021/02/25 - [IT/데이터베이스] - JPA 공부 - 6 JPA SYUDY 참고 서적 : 자바 ORM 표준 JPA 프로그래밍 학습 방식 책 정리 예제 코드 실습 PLAN (책 목차에 따라 진행) JPA 소개 (1주차) JPA 시작 (2주차) 영속성 관리 (3주차) 엔티티 매핑 (4주차) 연관관계 매핑 기초 (5주차) 다양한 연관관계 매핑(6주차) 고급 매핑 상..
백업과 복구 백업과 복구 지속성과 성능이 양립하는 구조 DBMS의 3가지 구조 트랜잭션에는 지속성이라는 성질이 있음 시스템 장애에도 지속성을 유지할 수 있어야함 DBMS 에서는 지속성과 성능이 양립할 수 있도록 하고 있음 로그선행 쓰기(WAL) 데이터 파일 변경을 직접 수행하지 않고 로그를 먼저 변경하고 변경사항을 기록한 로드 레코드를 써서 동기화 하는 구조 MySQL에서는 이 로그를 InnoDB 로그로 부름 WAL 의 장점 디스크에서 연속해서 쓰기 때문에 무작위로 쓰는 것보다 성능이 좋다. 트랜잭션이 발생하게 되면 이를 모두 Sequential 한 Log 형태로 보관 디스크에 쓰는용량과 횟수를 줄일 수 있다. Sequential 형태로 데이터를 나열하게 되면 특별한 연산이 필요가 없고 디스크 헤더 움직이도 적기 때..
트랜잭션과 동시성 제어 트랜잭션과 동시성 제어 트랜잭션이란? 갱신은 단일 쿼리가 아닌 복수 쿼리를 연속적으로 수행하는 경우가 대부분 또한 갱신 전에 조회를 포함해서 사용하는일이 많음 이러한 쿼리들을 한 덩어리로 포함하여 다뤄야 함 → 이런 복수 쿼리를 한 단위로 묶은 것 원자성 데이터의 변경을 수반하는 일련의 데이터 조작이 전부 성공할지, 전부 실패할지를 보증하는 구조 예를 들어 A, B, C 작업이 순차적으로 있을 경우 A → B → C 가 하일련의 데이터 조작으로 묶임 그리고 A, B, C 중 하나라도 실패할 경우 전부 롤백 A, B, C 를 하나의 원자 단위로 보는 관점 일관성 기존의 데이터 베이스가 데이터 조작 전후에 그 상태를 유지하는 것을 보증 이를 위해 데이터베이스에서는 오브젝트에 대해 각종 정합성 제약을 추가할 ..