国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Hibernate迫切連接和普通連接的區(qū)別實例詳解

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

2021-03-10 13:29__浮沉丶若軒◇ Java教程

這篇文章主要介紹了Hibernate迫切連接和普通連接的區(qū)別實例詳解,具有一定借鑒價值,需要的朋友可以參考下。

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
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)容,希望對大家有所幫助。如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

原文鏈接:https://www.cnblogs.com/songjianhui/p/6505122.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩亚洲一区二区 | 日韩视频在线免费播放 | 中文字幕在线观看一区二区三区 | 国产乱码精品一区二区三 | 在线精品一区 | 日韩成人在线一区二区 | 日韩欧美中文字幕在线视频 | 日韩一区久久 | 欧美一区二区最爽乱淫视频免费看 | 亚洲欧美一区二区三区情侣bbw | 97久久精品午夜一区二区 | 91精品国产乱码久久久久久久久 | 国产乱码精品一区二区三区中文 | 一级黄色大片在线 | 欧美精品一区二区在线观看 | 在线观看a毛片 | 91网在线| 欧美一区二区三区 | 毛片免费在线视频 | 国产成人jvid在线播放 | 精品在线看 | 日本欧美在线 | 精品亚洲一区二区 | 国产日韩欧美精品 | 精品国产91乱码一区二区三区 | 久久综合久色欧美综合狠狠 | 国产精品一区二区三区在线播放 | 羞羞的视频在线免费观看 | 欧美一级免费 | 亚洲成人一区 | 四虎影视免费看电影 | 日韩精品免费一区二区三区 | 在线国产一区二区 | 欧美一区二区三区在线看 | 欧美精品三区 | 在线一级毛片 | 九色porny国模私拍av | 色视频在线免费观看 | 亚洲成av人影片在线观看 | 中文字幕免费中文 | 色婷婷综合久久久中文字幕 |