亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Hibernate迫切連接和普通連接的區(qū)別實例詳解

 更新時間:2017年12月22日 10:28:20   作者:__浮沉丶若軒◇  
這篇文章主要介紹了Hibernate迫切連接和普通連接的區(qū)別實例詳解,具有一定借鑒價值,需要的朋友可以參考下。

Hibernate 迫切連接和普通連接的區(qū)別

相關(guān)的介紹和解釋在代碼中已注釋,大家可以參考。

package com.baidu.test;
import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import com.baidu.leftJoin.Department;
import com.baidu.leftJoin.Employee;
public class TestHQL_LeftJoin {
	private SessionFactory sessionFactory;
	private Session session;
	private Transaction transaction;
	@Before
	  public void init(){
		Configuration configuration = new Configuration().configure();
		ServiceRegistry serviceRegistry = new ServiceRegistryBuilder()
		                    .applySettings(configuration.getProperties())
		                    .buildServiceRegistry();
		sessionFactory = configuration.buildSessionFactory(serviceRegistry);
		session = sessionFactory.openSession();
		transaction = session.beginTransaction();
	}
	@After
	  public void destroy(){
		transaction.commit();
		session.close();
		sessionFactory.close();
	}
	// ~~~~~~~~~~~~~~~~~~~~~~~~~~下面的例子是 從 1 對 多  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
	/**
   *
   * 迫切左外連接: 特點是:如果左表有不滿足條件的,也返回左表不滿足條件
   *    1. LEFT JOIN FETCH 關(guān)鍵字表示迫切左外連接檢索策略.
   *    2. list() 方法返回的集合中存放實體對象的引用, 每個 Department 對象關(guān)聯(lián)的 Employee 集合都被初始化,
   *       存放所有關(guān)聯(lián)的 Employee 的實體對象.
   *    3. 查詢結(jié)果中可能會包含重復(fù)元素, 可以通過一個 HashSet 來過濾重復(fù)元素
   *
   *     去重:
   *       方法一:使用 distinct
   *         String hql = "SELECT DISTINCT d FROM Department d LEFT JOIN FETCH d.emps ";
   *        Query query = session.createQuery(hql);
   *
   *        List<Department> depts = query.list();
   *        System.out.println(depts.size());
   *       
   *       方法二
   *         String hql = "FROM Department d LEFT JOIN FETCH d.emps ";
   *        Query query = session.createQuery(hql);
   *
   *        List<Department> depts = query.list();
   *
   *        depts = new ArrayList<>(new LinkedHashSet(depts));
   *        System.out.println(depts.size());
   *        
   *        for(Department dept:depts){
   *          System.out.println(dept.getName() + "--" + dept.getEmps().size() );
   *        }
   *
   *
   */
	@Test
	  public void testLeftJoinFetch(){
		//    String hql = "SELECT DISTINCT d FROM Department d LEFT JOIN FETCH d.emps ";
		//    Query query = session.createQuery(hql);
		//    
		//    List<Department> depts = query.list();
		//    System.out.println(depts.size());
		//    
		String hql = "FROM Department d LEFT JOIN FETCH d.emps ";
		Query query = session.createQuery(hql);
		List<Department> depts = query.list();
		System.out.println(depts.size());
		depts = new ArrayList<>(new LinkedHashSet(depts));
		System.out.println(depts.size());
		for (Department dept:depts){
			System.out.println(dept.getName() + "--" + dept.getEmps().size() );
		}
	}
	/**
   * 左外連接:
   *    1. LEFT JOIN 關(guān)鍵字表示左外連接查詢.
   *    2. list() 方法返回的集合中存放的是對象數(shù)組類型
   *    3. 根據(jù)配置文件來決定 Employee 集合的檢索策略.
   *    4. 如果希望 list() 方法返回的集合中僅包含 Department 對象,
   *      可以在HQL 查詢語句中使用 SELECT 關(guān)鍵字
   *    
   *    這樣的語句查詢的結(jié)果有重復(fù):
   *      String hql = "FROM Department d LEFT JOIN d.emps";
   *      Query query = session.createQuery(hql);
   *    
   *      List<Object[]> results = query.list();
   *      System.out.println(results.size());
   *  
   *     去重:
   *       僅能使用 distinct 的方法去除重復(fù)
   *   
   *       String hql = "SELECT DISTINCT d FROM Department d LEFT JOIN d.emps";
   *       Query query = session.createQuery(hql);
   *
   *       List<Department> depts = query.list();
   *       System.out.println(depts.size());
   *         
   *       for(Department dept:depts){
   *         System.out.println(dept.getName() + dept.getEmps().size());
   *       }
   *
   */
	@Test
	  public void testLeftJoin(){
		String hql = "SELECT DISTINCT d FROM Department d LEFT JOIN d.emps";
		Query query = session.createQuery(hql);
		List<Department> depts = query.list();
		System.out.println(depts.size());
		for (Department dept:depts){
			System.out.println(dept.getName() + dept.getEmps().size());
		}
	}
	/**
   * 迫切內(nèi)連接: 特點是:不返回左表不滿足條件
   *    INNER JOIN FETCH 關(guān)鍵字表示迫切內(nèi)連接, 也可以省略 INNER 關(guān)鍵字
   *    list() 方法返回的集合中存放 Department 對象的引用, 每個 Department
   *        對象的 Employee 集合都被初始化, 存放所有關(guān)聯(lián)的 Employee 對象
   *
   * 內(nèi)連接:
   *    INNER JOIN 關(guān)鍵字表示內(nèi)連接, 也可以省略 INNER 關(guān)鍵字
   *    list() 方法的集合中存放的每個元素對應(yīng)查詢結(jié)果的一條記錄, 每個元素都是對象數(shù)組類型
   *    如果希望 list() 方法的返回的集合僅包含 Department 對象, 可以在 HQL 查詢語句中使用 SELECT 關(guān)鍵字
   *
   *
   *
   */
	@Test
	  public void testInnerJoinFetch(){
		//String hql = "SELECT DISTINCT d FROM Department d LEFT JOIN FETCH d.emps ";
		String hql = "FROM Department d INNER JOIN FETCH d.emps ";
		Query query = session.createQuery(hql);
		List<Department> depts = query.list();
		depts = new ArrayList<>(new LinkedHashSet(depts));
		System.out.println(depts.size());
		for (Department dept:depts){
			System.out.println(dept.getName() + "--" + dept.getEmps().size() );
		}
	}
	// ~~~~~~~~~~~~~~~~~~~~~~~~~~下面的例子是 從多 對 1  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
	@Test
	  public void testLeftJoinFetch2(){
		String hql = "FROM Employee e LEFT JOIN FETCH e.dept";
		Query query = session.createQuery(hql);
		List<Employee> emps = query.list();
		System.out.println(emps.size());
		for (Employee emp:emps){
			System.out.println(emp + " -- " + emp.getDept());
		}
	}
}

總結(jié)

以上就是本文關(guān)于Hibernate迫切連接和普通連接的區(qū)別實例詳解的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:

淺談hibernate急迫加載問題(多重外鍵關(guān)聯(lián))

Hibernate中Session增刪改查操作代碼詳解

如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

相關(guān)文章

  • 解析java中This的用法分析

    解析java中This的用法分析

    本篇文章是對java中This的用法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • Java日常練習題,每天進步一點點(58)

    Java日常練習題,每天進步一點點(58)

    下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你
    2021-08-08
  • java常用工具類 Date日期、Mail郵件工具類

    java常用工具類 Date日期、Mail郵件工具類

    這篇文章主要為大家詳細介紹了java常用工具類,包括Date日期、Mail郵件工具類,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • springboot的controller層的常用注解說明

    springboot的controller層的常用注解說明

    這篇文章主要介紹了springboot的controller層的常用注解說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • springboot整合 beatlsql的實例代碼

    springboot整合 beatlsql的實例代碼

    這篇文章主要介紹了springboot整合 beatlsql的實例代碼,BeetSql是一個全功能DAO工具,同時具有hibernate 優(yōu)點 & Mybatis優(yōu)點功能,有興趣的可以了解一下
    2017-05-05
  • java實現(xiàn)雙色球機選號碼生成器

    java實現(xiàn)雙色球機選號碼生成器

    這篇文章主要為大家詳細介紹了java實現(xiàn)雙色球機選號碼生成器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • Java通過正則表達式捕獲組中的文本

    Java通過正則表達式捕獲組中的文本

    這篇文章主要給大家介紹了關(guān)于利用Java如何通過正則表達式捕獲組中文本的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Java具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧下
    2019-09-09
  • Java 如何將前端傳來的數(shù)字轉(zhuǎn)化為日期

    Java 如何將前端傳來的數(shù)字轉(zhuǎn)化為日期

    這篇文章主要介紹了Java 如何將前端傳來的數(shù)字轉(zhuǎn)化為日期,本文通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • JAVA中堆、棧,靜態(tài)方法和非靜態(tài)方法的速度問題

    JAVA中堆、棧,靜態(tài)方法和非靜態(tài)方法的速度問題

    這篇文章主要介紹了JAVA中堆、棧,靜態(tài)方法和非靜態(tài)方法的速度問題,堆和棧得速度性能分析多角度給大家分析,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-08-08
  • java實現(xiàn)滑動驗證解鎖

    java實現(xiàn)滑動驗證解鎖

    這篇文章主要為大家詳細介紹了java實現(xiàn)滑動驗證解鎖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07

最新評論