> Java > Java인터뷰 질문들 > 자바 고주파 기본 면접 질문——(8)

자바 고주파 기본 면접 질문——(8)

王林
풀어 주다: 2020-09-11 15:59:04
앞으로
1837명이 탐색했습니다.

자바 고주파 기본 면접 질문——(8)

91, ORM이란 무엇입니까?

(추가 면접 질문 추천 : java 면접 질문 및 답변)

객체 관계형 매핑(ORM)은 프로그램의 객체지향 모델과 프로그램의 관계형 모델 간의 불일치를 해결하는 방법입니다.

간단히 말하면 ORM은 객체와 데이터베이스 간의 매핑을 설명하는 메타데이터를 사용하여 프로그램의 객체를 관계형 데이터베이스 또는 관계형 데이터베이스에 자동으로 유지합니다(Java에서는 XML 또는 주석을 사용할 수 있음). 관계형 데이터베이스 테이블을 Java 객체로 변환하는 것은 본질적으로 데이터를 한 형식에서 다른 형식으로 변환합니다.

92. Hibernate의 SessionFactory는 스레드로부터 안전합니까? 세션은 스레드로부터 안전합니까(두 스레드가 동일한 세션을 공유할 수 있습니까)?
SessionFactory는 Hibernate의 데이터 저장 개념에 해당하며 스레드로부터 안전하며 여러 스레드에서 동시에 액세스할 수 있습니다. SessionFactory는 일반적으로 시작 시에만 빌드됩니다. 애플리케이션의 경우 쉬운 액세스를 위해 싱글톤 모드를 통해 SessionFactory를 캡슐화하는 것이 가장 좋습니다.

Session은 데이터베이스와 상호 작용하는 작업 단위를 나타내는 스레드로부터 안전하지 않은 경량 개체입니다(스레드 간에 세션을 공유할 수 없음). 세션은 SessionFactory에 의해 생성되며 작업이 완료된 후 닫힙니다. 세션은 지속성 계층 서비스에서 제공하는 기본 인터페이스입니다.

세션은 데이터베이스 연결 획득을 지연시킵니다(즉, 필요할 때만 연결을 얻습니다). 너무 많은 세션이 생성되는 것을 방지하려면 ThreadLocal을 사용하여 세션을 현재 스레드에 바인딩하여 동일한 스레드가 항상 동일한 세션을 갖도록 할 수 있습니다. Hibernate 3에 있는 SessionFactory의 getCurrentSession() 메소드가 이를 수행할 수 있습니다.

93. Session의 save(), update(), merge(), lock(), saveOrUpdate() 및 persist() 메소드는 무엇입니까? 차이점은 무엇입니까?
   Hibernate 객체에는 임시, 지속, 분리의 세 가지 상태가 있습니다. 예 인스턴트 상태의 인스턴스는 Save(), Persist() 또는 SaveorUpdate()를 호출하여 변경할 수 있습니다. save() 및 persist()는 SQL INSERT 문을 트리거하고 update() 또는 merge()는 UPDATE 문을 트리거합니다.

save()와 update()의 차이점은 하나는 임시 객체를 지속 상태로 바꾸고, 다른 하나는 자유 객체를 지속 상태로 바꾼다는 것입니다. merge() 메서드는 save() 및 update() 메서드의 기능을 완료할 수 있으며, 그 목적은 새 상태를 기존 영속 객체에 병합하거나 새 영속 객체를 생성하는 것입니다.

                                                                      사용 사용 사용 사용                 사용 off ‐ off ‐ off ‐ ‐ '                                                                            . 2. persist() 메소드는 호출될 때 INSERT 문을 트리거하지 않도록 합니다. 트랜잭션 외부에서 긴 세션 프로세스를 캡슐화해야 하는 경우 persist() 메소드가 매우 필요합니다.

3. save() 메소드는 항목 2를 보장하지 않으므로 INSERT를 실행합니다. 거래 내부든 외부든 즉시 진술합니다. lock() 메서드와 update() 메서드의 차이점은 update() 메서드는 분리된 상태의 객체를 영구 상태로 변경하는 것입니다. lock() 메서드는 객체를 분리된 상태로 만듭니다. 그것은 지속적인 상태로 변하지 않았습니다.

94, 세션별로 엔터티 개체를 로드하는 과정을 설명합니다.
  1. 데이터베이스 쿼리 기능을 호출하기 전에 세션은 먼저 1단계 캐시의 엔터티 유형과 기본 키를 검색합니다. 1단계 캐시 검색에 도달하고 데이터 상태가 적법하면 직접 반환됩니다. 2. 1차 캐시에 도달하지 않으면 Session은 현재 NonExists 레코드를 검색합니다. (쿼리 블랙리스트와 동일합니다. 잘못된 쿼리가 반복적으로 나타나는 경우 빠른 판단을 통해 성능을 향상시킬 수 있습니다.) NonExists에 쿼리 조건이 있으면 null이 반환됩니다.
                                                                                                                                    2차 수준 캐시 쿼리가 실패하면 세션의 NonExists에 기록하고 null을 반환합니다.
5. ResultSet을 가져옵니다. 매핑 구성 및 SQL 문에 따라 해당 개체 개체를 생성합니다. 6. 개체를 세션 관리(레벨 1 캐시)에 통합합니다.
7. 해당 인터셉터가 있는 경우 onLoad 메서드를 실행합니다. 인터셉터;
8. 활성화되어 두 번째 수준 캐시를 사용하도록 설정된 경우 데이터 개체가 두 번째 수준 캐시에 포함됩니다.

95, MyBatis에서 자리 표시자를 작성하기 위해 #과 $를 사용하는 것의 차이점은 무엇입니까?数据#문자열로 전달된 데이터가 전달된 데이터에 자동으로 추가됩니다.

$는 전송된 데이터를 SQL에서 직접 표시합니다.

참고: $ 자리 표시자를 사용하면 SQL 주입 공격이 발생할 수 있습니다. #을 사용할 수 있는 경우에는 $를 사용하지 마세요. order by 절을 작성할 때는 # 대신 $를 사용해야 합니다.

96, MyBatis에서 네임스페이스의 역할을 설명하세요.

대규모 프로젝트에서는 SQL 문이 많을 수 있는데, 이때 각 SQL 문에 고유한 식별(ID)을 부여하는 것은 쉽지 않습니다. 이 문제를 해결하기 위해 MyBatis에서는 각 매핑 파일에 대해 고유한 네임스페이스를 생성하여 이 매핑 파일에 정의된 각 SQL 문이 이 네임스페이스에 정의된 ID가 되도록 할 수 있습니다. 이 ID가 각 네임스페이스에서 고유하다는 것을 확인할 수 있는 한, 서로 다른 매핑 파일의 명령문 ID가 동일하더라도 더 이상 충돌이 발생하지 않습니다.

(동영상 튜토리얼 추천:

java 강좌

)

97. MyBatis에서 동적 SQL은 무엇을 의미하나요?

일부 복잡한 쿼리의 경우 여러 쿼리 조건을 지정할 수 있지만 이러한 조건이 존재할 수도 있고 존재하지 않을 수도 있습니다. 지속성 계층 프레임워크를 사용하지 않으면 SQL 문을 직접 조립해야 할 수도 있지만 MyBatis는 동적 SQL 기능을 제공합니다. 이 문제를 해결하세요. MyBatis에서 동적 SQL을 구현하는 데 사용되는 요소는 주로 다음과 같습니다. - if - 선택 / when / else - Trim - where - 설정 - foreach

사용 예: