본문 바로가기

개발 관련/java11

Transactional 정리 Q. 스프링 프레임워크에서는 트랜잭션을 처리할 때 @Trasnactional 을 사용하는데, 이 @Transactional 어노테이션에는 7가지 전파 방법이 있다, 어떤 것들이 있는가? A. @Transactional 어노테이션을 사용하면 적용된 클래스 또는 메소드에 트랜잭션이 적용된다. 따라서 클래스에 할 것인지, 메소드에 할 것인지 판단을 잘 해야 한다. 7가지 Propagation(전파) 방법은 REQUIRED : 부모 트랜잭션 내에서 실행하며 부모 트랜잭션이 없을 경우 새로운 트랜잭션을 생성한다. REQUIREDS_NEW : 부모 트랜잭션을 무시하고 무조건 새로운 트랜잭션이 생성된다. SUPPORT : 부모 트랜잭션 내에서 실행하며 부모 트랜잭션이 없을 경우 nontransactionally 로 .. 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.