집 >Java >Java인터뷰 질문들 >자바 고주파 기본 면접 질문——(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 절을 작성할 때는 # 대신 $를 사용해야 합니다.
대규모 프로젝트에서는 SQL 문이 많을 수 있는데, 이때 각 SQL 문에 고유한 식별(ID)을 부여하는 것은 쉽지 않습니다. 이 문제를 해결하기 위해 MyBatis에서는 각 매핑 파일에 대해 고유한 네임스페이스를 생성하여 이 매핑 파일에 정의된 각 SQL 문이 이 네임스페이스에 정의된 ID가 되도록 할 수 있습니다. 이 ID가 각 네임스페이스에서 고유하다는 것을 확인할 수 있는 한, 서로 다른 매핑 파일의 명령문 ID가 동일하더라도 더 이상 충돌이 발생하지 않습니다.
(동영상 튜토리얼 추천:
java 강좌)
일부 복잡한 쿼리의 경우 여러 쿼리 조건을 지정할 수 있지만 이러한 조건이 존재할 수도 있고 존재하지 않을 수도 있습니다. 지속성 계층 프레임워크를 사용하지 않으면 SQL 문을 직접 조립해야 할 수도 있지만 MyBatis는 동적 SQL 기능을 제공합니다. 이 문제를 해결하세요. MyBatis에서 동적 SQL을 구현하는 데 사용되는 요소는 주로 다음과 같습니다. - if - 선택 / when / else - Trim - where - 설정 - foreach
사용 예:
98, JDBC 프로그래밍의 단점은 무엇이며 MyBatis는 이러한 문제를 어떻게 해결합니까?
1. JDBC: 데이터베이스 링크의 빈번한 생성 및 해제는 시스템 자원의 낭비를 초래하고 시스템 성능에 영향을 미칩니다. 이 문제는 데이터베이스 연결 풀을 사용하여 해결할 수 있습니다.
MyBatis: SqlMapConfig.xml에서 데이터 링크 풀을 구성하고 연결 풀을 사용하여 데이터베이스 링크를 관리합니다.
2. JDBC: SQL 문이 코드에 작성되어 코드를 유지 관리하기가 어렵습니다. SQL의 실제 적용은 크게 변경될 수 있으며, SQL 변경에는 Java 코드 변경이 필요합니다.
MyBatis: XXXXmapper.xml 파일에 Sql 문을 구성하고 이를 Java 코드와 분리합니다.
3. JDBC: sql 문의 where 조건이 반드시 확실하지 않고 다소 클 수 있으며 자리 표시자가 매개 변수와 일대일로 대응해야 하기 때문에 sql 문에 매개 변수를 전달하는 것이 번거롭습니다. .
MyBatis: MyBatis는 자동으로 Java 개체를 SQL 문에 매핑합니다.
4. JDBC: 결과 집합을 구문 분석하는 것이 번거롭습니다. SQL 변경으로 인해 구문 분석 코드가 변경되고, 구문 분석하기 전에 데이터베이스 레코드를 pojo 객체로 구문 분석하는 것이 더 편리합니다.
MyBatis: MyBatis는 SQL 실행 결과를 Java 개체에 자동으로 매핑합니다.
99, MyBatis와 Hibernate의 차이점은 무엇입니까?
1. MyBatis는 프로그래머가 Sql 문을 직접 작성해야 하기 때문에 완전히 ORM 프레임워크는 아닙니다. 그러나 mybatis는 XML 또는 주석을 통해 실행되도록 SQL 문을 유연하게 구성할 수 있으며 Java 개체와 sql 문을 매핑하면 최종적으로 실행되는 sql이 생성되고, 최종적으로 sql 실행 결과가 매핑되어 java 객체가 생성됩니다.
2. Mybatis는 학습 임계값이 낮고 배우기 쉽습니다. 프로그래머가 원본 SQL을 직접 작성할 수 있어 SQL 실행 성능을 엄격하게 제어할 수 있으며 유연성이 뛰어나 관계형 데이터에 대한 요구 사항이 높지 않은 소프트웨어 개발에 매우 적합합니다. 인터넷 소프트웨어, 기업 운영 등의 모델. 이러한 유형의 소프트웨어 요구 사항은 자주 변경되므로 요구 사항이 변경되면 결과가 신속하게 출력되어야 합니다. 그러나 유연성의 전제는 mybatis가 데이터베이스 독립적일 수 없다는 것입니다. 여러 데이터베이스를 지원하는 소프트웨어를 구현해야 하는 경우 여러 세트의 SQL 매핑 파일을 사용자 정의해야 하며 이는 작업량이 많습니다. 3. Hibernate는 강력한 객체/관계 매핑 기능과 우수한 데이터베이스 독립성을 가지고 있습니다. 관계형 모델에 대한 요구 사항이 높은 소프트웨어(예: 고정 요구 사항이 있는 맞춤형 소프트웨어)의 경우 Hibernate를 사용하여 개발하면 많은 비용을 절감할 수 있습니다. 코드를 작성하고 효율성을 향상시킵니다. 하지만 Hibernate의 단점은 학습의 문턱이 높고, 숙달의 문턱이 더욱 높다는 점이다. 더욱이 O/R 매핑을 어떻게 설계할지, 성능과 객체 모델을 어떻게 가늠할지, Hibernate를 잘 활용하려면 어떻게 해야 하는지가 필요하다. 강력한 경험과 능력. 的 즉, 제한된 리소스 환경에서 사용자의 요구 사항을 충족할 수 있는 한 유지 관리가 좋고 확장성이 좋은 소프트웨어 아키텍처가 좋은 아키텍처이므로 프레임워크는 프레임워크에만 적합합니다.
Java 입문 튜토리얼
위 내용은 자바 고주파 기본 면접 질문——(8)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!