亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Hibernate迫切連接和普通連接的區別實例詳解

2024-07-13 10:15:14
字體:
來源:轉載
供稿:網友

Hibernate 迫切連接和普通連接的區別

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

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 關鍵字表示迫切左外連接檢索策略.   *    2. list() 方法返回的集合中存放實體對象的引用, 每個 Department 對象關聯的 Employee 集合都被初始化,   *       存放所有關聯的 Employee 的實體對象.   *    3. 查詢結果中可能會包含重復元素, 可以通過一個 HashSet 來過濾重復元素   *   *     去重:   *       方法一:使用 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 關鍵字表示左外連接查詢.   *    2. list() 方法返回的集合中存放的是對象數組類型   *    3. 根據配置文件來決定 Employee 集合的檢索策略.   *    4. 如果希望 list() 方法返回的集合中僅包含 Department 對象,   *      可以在HQL 查詢語句中使用 SELECT 關鍵字   *       *    這樣的語句查詢的結果有重復:   *      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 的方法去除重復   *      *       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());		}	}	/**   * 迫切內連接: 特點是:不返回左表不滿足條件   *    INNER JOIN FETCH 關鍵字表示迫切內連接, 也可以省略 INNER 關鍵字   *    list() 方法返回的集合中存放 Department 對象的引用, 每個 Department   *        對象的 Employee 集合都被初始化, 存放所有關聯的 Employee 對象   *   * 內連接:   *    INNER JOIN 關鍵字表示內連接, 也可以省略 INNER 關鍵字   *    list() 方法的集合中存放的每個元素對應查詢結果的一條記錄, 每個元素都是對象數組類型   *    如果希望 list() 方法的返回的集合僅包含 Department 對象, 可以在 HQL 查詢語句中使用 SELECT 關鍵字   *   *   *   */	@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());		}	}}

總結

以上就是本文關于Hibernate迫切連接和普通連接的區別實例詳解的全部內容,希望對大家有所幫助。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产91| 日韩电影中文 亚洲精品乱码| 91精品久久久久久久久久入口| 亚洲第一在线视频| 国产精品第3页| 亚洲精品美女久久| 中文字幕欧美精品日韩中文字幕| 尤物yw午夜国产精品视频明星| 成人黄色片网站| 国产精品高潮呻吟久久av无限| 欧美极品少妇xxxxⅹ免费视频| 亚洲free性xxxx护士hd| 欧美亚洲在线视频| 亚洲女在线观看| 精品久久久在线观看| 欧美限制级电影在线观看| 欧美精品在线看| 日韩中文在线中文网三级| 国产午夜精品视频| 国产成人福利网站| 日韩精品在线观看视频| 大胆人体色综合| 日韩精品中文在线观看| 97超碰国产精品女人人人爽| 国产在线视频不卡| 黄色成人在线播放| 国产精品久久久久久久久久ktv| 国产午夜精品免费一区二区三区| 亚洲午夜精品久久久久久久久久久久| 亚洲国产精品大全| 亚洲aaa激情| 久久精品中文字幕| 欧美xxxx做受欧美| 日本亚洲欧美三级| 成人久久久久爱| 色无极亚洲影院| 亚洲自拍偷拍在线| 欧美不卡视频一区发布| 亚洲福利视频二区| 成人h视频在线观看播放| 91成人在线视频| 亚洲色图综合久久| 国产成人精品一区| 一二美女精品欧洲| 亚洲成人精品久久久| 亚洲欧美国产高清va在线播| 深夜福利国产精品| 欧美一级淫片丝袜脚交| 51午夜精品视频| 91在线精品视频| 欧美亚洲成人网| 亚洲二区中文字幕| 亚洲一区999| 亚洲电影免费观看高清完整版在线| 国产91亚洲精品| 亚洲第一精品电影| 久久久91精品| 精品偷拍一区二区三区在线看| 亚洲一区二区三区在线免费观看| 91在线高清免费观看| 一区二区在线免费视频| 日韩动漫免费观看电视剧高清| 久久精品视频导航| 九九热这里只有精品免费看| 久久免费精品视频| 色狠狠av一区二区三区香蕉蜜桃| 91精品视频在线播放| 亚洲一区二区久久| 欧美亚洲视频在线观看| 亚洲精品国产精品国自产观看浪潮| 日韩精品中文字幕久久臀| 日韩在线观看网址| 欧美韩日一区二区| 亚洲精品久久久久久久久久久| 久久久久成人精品| 欧美裸身视频免费观看| 97精品国产97久久久久久春色| 亚洲在线观看视频网站| 精品国产依人香蕉在线精品| 国产欧美一区二区三区在线| 国产一区二区三区毛片| 日韩av中文字幕在线播放| 欧美激情亚洲国产| 亚洲美女黄色片| 亚洲人成五月天| 国产日韩欧美中文| 欧美国产视频一区二区| 成人欧美一区二区三区黑人孕妇| 国产日韩欧美黄色| 9.1国产丝袜在线观看| 日韩av在线免费观看| 欧美激情第一页xxx| 久久亚洲精品视频| 欧美日产国产成人免费图片| 久久久久久久久爱| 欧美在线一级视频| 亚洲一区久久久| 92国产精品视频| 久久伊人精品天天| 精品久久久久久久久久久| 色偷偷9999www| 国产精品69精品一区二区三区| 国内伊人久久久久久网站视频| 欧美日韩日本国产| 91在线视频一区| 日韩电影中文 亚洲精品乱码| 国产精品旅馆在线| 成人妇女淫片aaaa视频| 日韩电视剧免费观看网站| 中文字幕亚洲无线码a| 欧美午夜美女看片| 国产91亚洲精品| 色综合久综合久久综合久鬼88| 国产精品成人aaaaa网站| 91在线无精精品一区二区| 欧美在线视频一区二区| 美女福利视频一区| 国产精品亚洲欧美导航| 国产不卡av在线| 国产日本欧美在线观看| 欧美专区中文字幕| 日韩欧美亚洲成人| 国产精品99蜜臀久久不卡二区| 国产精品美女久久久免费| 777国产偷窥盗摄精品视频| 国产精品一区二区三区成人| 久久久久久久久久久av| 久久久久久久久久久人体| 91av视频在线观看| 亚洲a一级视频| 中文字幕在线日韩| 成人欧美在线观看| 日韩av成人在线| 欧美乱妇40p| 亚洲一区av在线播放| 久久九九亚洲综合| 欧美极品少妇xxxxx| 欧美日韩加勒比精品一区| 97精品视频在线| 欧美二区在线播放| 亚洲成年人在线| 欧美在线观看网站| 国产99久久精品一区二区 夜夜躁日日躁| 91午夜理伦私人影院| 精品久久久久久亚洲国产300| 色综合色综合久久综合频道88| 亚洲天堂一区二区三区| 97色在线观看免费视频| 91免费精品国偷自产在线| 日本久久久久久久久| 96精品久久久久中文字幕| 日韩在线播放一区| 国产精品∨欧美精品v日韩精品| 亚洲天堂2020| 久久视频免费观看| 国产精品久久久久国产a级| 成人久久一区二区| 日韩毛片在线看| 日韩极品精品视频免费观看| 亚洲乱码av中文一区二区| 久久伊人精品天天| 欧美精品videos| 国产日韩亚洲欧美| 亚州国产精品久久久|