본문 바로가기

Today37

24/01/11 면접 질문 5. HTTP 메서드에 대해 설명해주세요. 클라이언트가 웹서버에게 요청하는 목적을 알리는 수단을 말하고 그 종류는 여러가지가 있는데 주요 종류를 말하면 GET,POST,PUT,PATCH,DELETE가 있습니다. 여기서 PUT이랑 PATCH는 둘다 데이터를 갱신하기 인데 차이점은 PUT은 모든 데이터 갱신 PATCH는 일부 데이터 갱신입니다. 하지만 정의만 이렇고 실제 현업에서는 데이터 갱신을 POST로 하는곳도 많고,일부만 하는데 PUT으로 하는곳도 있습니다. 이제 기타 메소드로는 HEAD,OPTIONS,CONNECT,TRACE 들이 있는데 아직 사용해본적은 없습니다. 6. CORS(Cross Origin Resource Sharing)에 대해 설명해주세요. CORS는 웹 브라우저가 다른 출처.. 2024. 1. 11.
24/01/10 면접 질문 RDBMS의 정규화에 대해 설명해주세요. 관계형 데이터 베이스의 데이터의 중복을 줄이고, 무결성을 향상시킬 수 있는것을 말합니다. 정규화에는 여러가지 방법 있는데 제가 알고 있는 3가지 방법에 대해 말하면 첫번째 방법은 테이블에 한 컬럼에 데이터 한개만 갖도록 하는것 두번재 방법은 테이블의 모든 컬럼이 완전 함수적 종속을 만족해야하고 이를 위해 테이블을 적절히 분리하여 각 테이블이 한 개의 주제에 집중하도록 하는것 세번째 방법은 이행적 종속성을 제거하는데 초점을 맞추는데 이행적 종속이란 A → B, B → C면 A → C가 성립되는걸 말하고 이걸 피하기 위해 중복 되면 안되고 독립적으로 유지 해야하는것 Primary Key, Foreign Key에 대해 설명해주세요. PK는테이블 내의 모든 레.. 2024. 1. 9.
24/01/08 면접 질문 정리 1.NoSQL과 RDBMS의 특징과 차이점에 대해서 장, 단점을 들어 설명해주세요. RDBMS는 관계형 데이터 베이스라 하고 데이터는 정해진 데이터 스키마에 따라 테이블에 저장하고,관계를 통해 여러 테이블에 분산됩니다. 장점: 명확하게 정의된 스키마, 데이터 무결성 보장한다. 단점: 데이터 스키마를 사전에 계획하고 설정해야해서 나중 수정하기 어렵고 관계가 많을시 조인문으로 복잡한 쿼리문을 만들수도 있다. NOSQL은 반대로 비관계형 데이터 베이스라 하고 ,스키마랑 관계도 없습니다. 데이터는 관련 데이터를 동일한 "컬렉션"에 넣습니다. 장점:NoSQL은 스키마가 유연하고 데이터 구조가 다양하며 대량의 데이터를 저장하고 처리하는 데 특화되어 있다 단점: 데이터 중복을 계속 업데이트 해야하고,.. 2024. 1. 8.
24/01/14 1.레코드 클래스란? 자바 14에서 도입된 클래스이고,데이터 캐리어 클래스(즉, 단순히 데이터를 포함하고 POJO(Plain Old Java Objects) 및 DTO(Data)라고도 알려진 모듈 간에 데이터를 전달하는 것이 목적인 클래스)를 생성하는 빠른 방법으로 사용하려는 의도이고 자바 컴파일러로 인해 자동으로 필드들을 불변객체, getter, hashCode(), equals() ,toString(), public constructor를 자동으로 생성해준다. 그리고 Jackson을 이용해 레코드 클래스를 json으로,json을 레코드 클래스로 변환 가능하다 예시 코드 빌더를 이용한 예시 @Builder public record CartGameDTO( Long gameId, String gameNam.. 2024. 1. 4.
24/01/02 문제 특정 보드 ID에 관한 연결된 컬럼들이랑 그 각 컬럼들에 연결된 카드들 가져올때 N+1 문제 발생 먼저 코드를 보면 중간 테이블을 이용해서 특정 ID 보드를 가져오고 그 보드에서 연결된 컬럼들을(columnList) 가져온다. 그후 columnList에 들은 각 컬럼들에서 또 연결된 카드들을(columns.getCards() )가져오는데 N+1문제가 생긴다. 결국 이렇게 쿼리문이 5개 나간다.(해당 보드에 연결된 컬럼이 총5개) 원인 컬럼에 카드랑 연결관계인 cards필드를 지연로딩으로 설정해서 각 컬럼의 cards에 접근할때 쿼리문을 따로따로 날려서 컬럼 총 갯수만큼 쿼리문이 나간다. 해결 Fetch Join을 이용해서 총 컬럼의 정보를 가져올때 동시에 각 컬럼에 들은 카드정보도 가져온다. 특정 .. 2024. 1. 2.
23/12/26 연관 관계 단방향 영속성 전이 Remove오류 일단 테이블이 유저-게시글-댓글 이있고 관계는 게시글(N)-유저(1): 단방향 댓글(N)-게시글(1): 양방향 문제 게시글 엔티티에서 댓글이랑 연관관계 설정한 필드에 영속성 전이 Remove를 걸고 게시글 삭제시 해당 게시글이랑 연결된 댓글도 자동으로 삭제 할 줄 알았으나 게시글에 연결된 유저도 삭제를 시도 한다해서 오류가 난다. 원인 게시글이랑 유저는 단방향이라 누가 부모인지 몰라서 그렇다. 해결 1.방법은 게시글에 연결된 데이터를 따로 먼저 다 삭제 해주고 그다음 게시글을 삭제 해준다. 해당 댓글 부터 다 삭제후 게시글 삭제 2.유저랑 게시글도 그냥 양방향으로 한다.(외래키 설정 했을시) 하지만 실제 일할땐 많이들 외래키 설정 안하고 참조 id만 설정하고.. 2023. 12. 26.
23/12/18 JDK: Java Development Kit인 자바 프로그래밍 언어를 개발하기 위한 도구들의 집합을 말하고 JDK는 컴파일러(.java파일을 .class로 변환),JRE,JVM,표준 라이브러리 및 도구들(개발 및 디버깅 도구)을 포함한다. JRE: Java Runtime Environment인 자바 실행환경을 말한다. 자바 프로그램을 실행하기 위해 필요한 라이브러리, 클래스, JVM, 기타 지원 파일 등을 포함하고 있다. 자바 프로그램을 개발하는 데는 JDK가 필요하지만, 자바 프로그램을 실행하는 데에는 JRE만 있으면 된다. JVM: Java Virtual Machine인 자바 가상 머신으로, 자바 애플리케이션을 실행하기 위한 가상 컴퓨터를 말한다. 하지만 다른 플랫폼(윈도우7,10,11,맥,리눅스등.. 2023. 12. 18.
23/12/15 아웃소싱 팀 프로젝트 회고 우리가 JPA를 사용하면서 연관관계를 형성하지 않고 외래키(Id)만을 필드로 두면서 엔티티를 설계한 이유 JPA를 사용하면서 객체 그래프 탐색할 때 실행되는 쿼리가 궁금해졌다. JPA는 연관관계만 설정해 주면 해당 연관관계에 접근했을 때, 자동으로 쿼리를 실행해 준다. 이 자동으로 실행되는 쿼리는 우리가 예상하지 못하는 무수히 많은 수의 쿼리가 실행될 수도 있고, 성능상 좋지 못한 쿼리가 실행될 수도 있다. 그래서 예상되는 쿼리를 데이터베이스 조인을 통해 우리가 SQL로 직접 작성하여 실행함으로써 연관관계에 대한 객체 그래프 탐색을 SQL을 통해 구현하기로 하였다. 혹시나 다음에 다른 ORM으로 변경되더라도, 우리가 작성한 코드의 큰 변경없이 마이그레이션하기 좋고, 유지보수가 .. 2023. 12. 15.
23/12/14 AOP aop는 관점 지향 프로그래밍이라 불리고 핵심 기능과 부가 기능을 분리하여 애플리케이션 전체에 걸쳐 사용되는 부가 기능을 모듈화하여 재사용할 수 있도록 지원하는 것이다 어드바이스 부가기능을 핵심기능에 언제 수행할 건지를 정하는 것이다. (핵심기능 실행전 or 실행후 or 전후 전부 or 핵심기능이 오류가 난다면 예외 터지면 그때 수행 or 핵심기능 예외없이 성공후 수행) @Around: '핵심기능' 수행 전과 후 (@Before + @After) @Before: '핵심기능' 호출 전 (ex. Client 의 입력값 Validation 수행) @After: '핵심기능' 수행 성공/실패 여부와 상관없이 언제나 동작 (try, catch 의 finally() 처럼 동작) @AfterReturning: .. 2023. 12. 14.