본문 바로가기

자바12

JPA 어노테이션 1. NotFound org.hibernate.annotations 에 포함되어 있음 @JoinColumn 등으로 조인을 했을 시, 조인한 테이블의 값이 null 일 경우 EntityNotFoundException 이 발생하는데, 이럴 경우 @JoinColumn("dto_id") @NotFound(action = NotFoundAction.IGNORE) private DTO dto; 을 해주면 Exception 이 발생하지 않음. Ignore, Exception 2개의 값이 있는데 default 는 Exception 인 모양이다. 2. Transient javax.persistence 에 포함되어 있음 Entity 에 변수는 있으나, 컬럼과의 매핑을 원하지 않는 경우 사용 @Transient privat.. 2022. 7. 14.
JPA 락에 대해 트랜잭션에 대해서 이야기 하다보면은 항상 나오는 얘기가 있는 것 같습니다. 대량의 트래픽이 한 번에 들어왔을 때 어떻게 줄을 세울 것인가? 물론 아닐 수도 있지만, 면접때는 거의 항상 비슷한 내용을 물어봤던 것 같습니다 여러 방법이 있을 것 같습니다. DB 의 isolation level 을 조정한다던가 (하지만, 심각하게 느려지므로 비추인 것 같습니다.) JPA 의 낙/비관적 락을 사용한다던가 레디스를 통해 받는다던가 (클러스터를 사용하면 zookeeper 를 사용해야 한다던가 하는데, 자세히는 모르겠네요.) 알아본 혹은 알고 있는 방법으로는 3가지 정도가 있는 것 같습니다. 이번엔 JPA 의 락에 대해서 알아보려고 합니다. 1. 락 없이 동시 접근을 했을 때 동일한 데이터에 접근하여 수정하는 예로는 .. 2022. 7. 14.
멀티쓰레드에서 Thread-Safe 방법 1. 멀티 쓰레드(Multi Thread)란? 1-1) 정의 하나의 프로세스를 다수의 실행 단위로 구분하여 자원을 공유하고, 자원의 생성과 관리의 중복성으 최소화하여 수행능력을 향상시키는 것 하나의 프로그램에 동시에 여러개의 일을 수행할 수 있도록 해주는 것 1-2) 멀티 프로세스와의 차이점 멀티 프로세스 : [데이터, 힙, 스택] 영역 모두 비공유 멀티 쓰레드 : [데이터, 힙, 스택] 영역 중 스택만 비공유 2. 쓰레드 세이프 방법 쓰레드를 사용하는 환경에서 성능을 높이기 위해서 멀티 쓰레드를 사용하지만, 힙과 데이터영역은 공유하기 때문에 쓰레드 간에 safe 하지 못하게 됩니다. 1) Synchronized private Integer count = 0; synchronized (count) { c.. 2022. 7. 14.
orElse 와 orElseGet 무슨 차이가 있을까? Java 8을 쓰면서 null 에 대한 처리를 위해서 Optional 을 많이 쓸 텐데요. 저도 꽤 즐겨 쓰는 편입니다. (보통 null 을 반환하는 로직을 짜고 싶지 않겠지만, 그게 항상 마음대로 되지는 않잖아요..) 또한 적절하게 쓰면 코드 길이를 줄여 한 줄로 가능하다는 장점도 있고요. Optional 에는 orElse() 라는 메소드와 orElseGet() 이라는 메소드가 있는데요. 둘 다 Optional 을 통해 가져온 값이 null 일 때는 해당 값을 반환하라는 메소드 입니다. 최근에 관련 메소드를 쓰다가 전혀 생각지도 못한 곳에서 에러가 나서 재배포를 한 기억이 있는데요. (핫픽스를 통해 재배포를 했습니다. 하하..) 그러면 좀 더 잘 알고 사용하여, 다음엔 같은 에러를 발생시키지 않도록 정.. 2022. 7. 14.
SimpleJdbcInsert 문제 이전 jdbcTemplate 를 설명하면서 simpleJdbcInsert 에 대한 칭찬(?)을 했었다. @Override public Long saveLoginUI(final LoginVO loginVO) { KeyHolder keyHolder = new GeneratedKeyHolder(); jdbcTemplate.update(new PreparedStatementCreator() { @Override public PreparedStatement createPreparedStatement(final Connection connection) throws SQLException { PreparedStatement statement = connection.prepareStatement("insert into.. 2022. 7. 14.
DB Insert 시 자동생성된 id 를 알아내기 DB Insert 시 자동생성된 id 를 알아내기 1.Mybatis INSERT INTO student ( name, grade, phone ) VALUES ( #{name}, #{grade}, #{phone} ) 사용하는 데이터베이스가 Auto Increment 가 된다면 (e.g. MySQL, Maria) 다음을 통해 id 를 알아낼 수 있다. StudentDTO student = StudentDTO.builer(). .name("snack") .grade(1) .phone(01011112222) .build(); mapper.insertStudent(student); student.getId() // get ID 2. KeyHolder 를 사용한 방법 MyBatis 를 사용하지 않고, jdbcTem.. 2022. 7. 14.