분류 전체보기
-
[Java] 인터페이스와 추상 클래스 차이는 무엇일까?Language/Java 2021. 8. 7. 01:47
인터페이스와 추상 클래스 차이는? 이번 글에서는 인터페이스와 추상 클래스의 차이에 대해서 정리해보겠습니다. 실제로 이 질문은 면접에서도 자주 물어보는 질문이고, 약간 알듯 말듯 한데 대답하기는 애매한 주제라 한번 각각 특징에 대해서 정리해보고 둘의 차이를 정리 해보겠습니다. 추상 클래스 클래스를 설계도에 비유한다면 추상 클래스는 미완성 설계도에 비유할 수 있습니다. 추상 클래스는 키워드 abstract를 붙이기만 하면 됩니다. public abstract class Test {} 추상 클래스는 추상 메소드를 0개 이상 가지고 있다는 것을 제외하고는 일반 클래스와 전혀 다르지 않습니다. 추상 메소드는 간단하게 말하면 선언부는 있는데 구현부가 없는 메소드를 의미합니다. public class 쥐 extend..
-
[MySQL] InnoDB 언두(Undo) 로그와 MVCC란 무엇일까?Book/Real MySQL 2021. 7. 29. 16:17
언두 영역이란? 언두 영역은 UPDATE 문장이나 DELETE 문장으로 데이터를 변경했을 때 변경되기 전의 데이터(이전 데이터)를 보관하는 곳입니다. UPDATE membere SET name='홍길동' WHERE member_id = '1'; 위 문장의 실행되면 트랜잭션을 커밋하지 않아도 실제 데이터 파일 내용은 홍길동으로 변경됩니다. 그리고 변경되기 전의 값이 Gyunny 였다면, 언두 영역에는 Gyunny라는 값이 백업되는 것입니다. 이 상태에서 사용자가 커밋하게 되면 현재 상태가 그대로 유지되고, 롤백하게 되면 언두 영역의 백업된 데이터를 다시 데이터 파일로 복구합니다. 언두의 데이터는 크게 두 가지 용도로 사용됩니다. 트랜잭션의 롤백 대비용 트랜잭션의 격리 수준을 유지하면서 높은 동시성을 제공 ..
-
1일 1커밋을 1년 7개월 동안 하면서 느낌점Retrospect 2021. 7. 29. 13:52
1일 1커밋을 1년 7개월 동안 해오면서... 이번 글에서는 제가 1일 1커밋을 1년 7개월 동안 하면서 느낀점에 대해서 간단하게 회고를 해보려 합니다! (Github) 1일 1커밋을 왜 시작했는지? 1일 1커밋을 지속할 수 있었던 것들은 어떤 것이 있었는지? 1일 1커밋에 대한 장단점! 자주 받았던 간단한 질문들 정리~? 이정도에 대해서 가볍게 회고하면서 저의 생각을 공유해보려 합니다. 바로 본론으로 고고싱! 1일 1커밋을 왜 시작했는지? 🤔🤔 1일 1커밋에 대해서 다른 사람과 얘기를 하다 보면 1일 1커밋을 왜 시작했는지 라는 질문을 아주 많이 받았습니다.(동아리 면접 때도 자주 들었던 질문!) 왜 시작했는지? 대해 얘기하려면 2019년으로 가야 하는데요. 2019년의 저는 간단한 개발 조차 해본 적..
-
[MySQL] COUNT 쿼리와 숫자 타입에 대한 주의 사항카테고리 없음 2021. 7. 26. 15:30
MySQL COUNT() 함수 정리 COUNT 함수는 모두가 알고 있듯이 결과 레코드의 건수를 반환하는 함수입니다. COUNT() 함수는 컬럼이나 표현식을 인자로 받고, COUNT(*)와 같이도 사용할 수 있습니다. 여기서 *는 SELECT 절에 사용될 때처럼 모든 컬럼을 가져오라는 의미가 아니라 그냥 레코드 자체를 의미하는 것입니다. 실제로 COUNT()이라고 해서 레코드의 모든 컬럼을 읽는 형태로 처리하지는 않습니다. 그래서 굳이 COUNT(id), COUNT(1) 같이 사용하지 않아도 됩니다. COUNT()와 비슷한 속도로 처리된다고 합니다. (오.. 뭔가 차이가 있을 줄 알았지만 차이가 없다니~!!) MyISAM 스토리지 엔진을 사용하는 테이블은 항상 테이블의 메타 정보에 전체 레코드 건수를 관리..
-
[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 파일을 읽어 해당 파일에 적힌 배포 단계에 맞게 스크립트 파일을 실행시키면서..