전체 글
-
[MySQL] Upsert 쿼리란 무엇일까?Book/Real MySQL 2021. 7. 22. 16:21
MySQL Upsert 사용법 이번 글에서는 MySQL에서 Upsert 쿼리를 사용하는 법에 대해서 정리해보겠습니다. Upsert는 이름에서 어느정도 유추할 수 있듯이 Update + Insert를 합친 말입니다. 즉, Upsert는 중복되는 값이 있다면 Update를 하고 중복되는 값이 없다면 Insert를 하는 쿼리입니다. 좀 더 정확히 말하면 Unique Key의 값이 중복된다면 Update를 하고, Unique 컬럼의 값이 존재하지 않는다면 INSERT를 하는 것입니다. 실제로 프로젝트를 하다 보니 이러한 쿼리를 사용해야 할 상황이 와서 이렇게 정리를 하게 되었습니다. Upsert 쿼리를 보면 아래와 같습니다. INSERT INTO user_refresh_token (user_id, refresh..
-
[MyBatis] MyBatis Reflection 에러 정리Server/MyBatis 2021. 7. 19. 00:58
MyBatis ResultMap 에러 정리 이번 글에서는 프로젝트를 하면서 만났던 MyBatis 에러에 대해서 간단하게 정리를 해보려 합니다. 현재 UserLeaderScore 모델과 User 모델을 ResultMap을 사용해서 JOIN 해서 데이터를 가져오려는 상황입니다. DB 테이블은 위와 같습니다. 이 테이블과 매칭이 되는 자바 클래스 모델은 아래와 같습니다. User Model @NoArgsConstructor @Getter public class User { private Long id; private String nickname; private String gender; private int birth; private String socialType; private String signupCo..
-
[Intellij] 인텔리제이에서 환경변수 설정하는 방법Tool/Intellij 2021. 7. 13. 13:51
들어가기 전에 이번 글에서는 Intellij에서 env 설정을 하고 이것을 application.yml에서 참조하는 법에 대해서 알아보겠습니다. 이렇게 하고자 하는 이유는 지금까지는 jwt secret key 라던지, DB url, DB id, DB pw 같은 것들을 yml 파일에 적은 후에 gitignore에 등록하고 Github에 올리지 않는 방법을 선택했습니다. 하지만 이것도 하나의 방법일 순 있겠지만, 자꾸 실수로 Github에 yml을 올리는 실수를 할 수도 있다는 것 때문에.. 이번에는 Intellij에서 환경변수를 등록하고 yml에서 해당 환경변수를 참조해서 사용하도록 바꿔보겠습니다. Intellij에서 env 설정 후 yml 파일에서 참조하는 법 인텔리제이 오른쪽 위를 보면 위와 같이 Ed..
-
[AWS] Spring + Github Actions + CodeDeploy로 CI/CD 하기 2편Cloud/AWS 2021. 7. 12. 17:23
Github Action, CodeDeploy로 CI/CD 하기 - 2편 저번 글 에서 Github Actions로 프로젝트 빌드를 수행한 후에 jar 파일을 S3로 업로드 하는 것까지 알아보았습니다. 이번 글에서는 S3에 업로드 된 zip 파일을 CodeDeploy-Agent를 통해서 EC2에 자동으로 배포를 하는 CD를 하는 법에 대해서 알아보겠습니다. CodeDeploy 배포 과정 개발하고 있는 프로젝트 최상단 경로에 appspec.yml 이라는 파일을 작성합니다. (이 파일에서 각 배포 단계에서 어떤 스크립트 파일을 실행할 것인지 명시할 수 있습니다.) Agent는 S3에서 zip 파일을 내려 바고, appspec.yml 파일을 읽어 해당 파일에 적힌 배포 단계에 맞게 스크립트 파일을 실행시키면서..