HQL提供了连接查询机制如内连接,外连接,,还允许显示指定迫切内连接,和迫切外联结。

连接类型

内连接 inner join 或join

迫切内链接 inner join fetch

左外联结  left outer join 或 join

迫切左外连接 left outer join fetch 或 left join fetch

右外连接 right outer join 或 right join

1.内连接

@Test
    //02.隐式内连接
    public void testHideInnerJoin(){
        Query query = session.createQuery("from Emp e where e.dept.deptName='开发部'");
        List<Emp> list = query.list();
        for (Emp emp : list) {
            System.out.println(emp.getEmpName());
        }
    }

2.迫切内连接

@Test
    public void innerJoinTest(){
        Query query = session.createQuery("select distinct d from Dept d inner join  d.emps");
        List<Dept> list = query.list();
        for (Dept dept : list) {
     System.out.println(dept.getDeptName());
            for (Emp emp : dept.getEmps()) {
                System.out.println(emp.getEmpName());
            }
        }
    }

3.左外连接

from Entity left join [fetch] Entity.propert

右外连接

from Entity right join Entity.property

注意:fetch关键字只对inner join 和 left join 有效。对于righ join 而言,由于作为关联对象

容器的“左边”对象可能为null,所以也就是无法通过fatch关键字强制Hibernate进行填充操作。

二,查询性能优化

1.Hibernate主要从以下方面查询性能。

使用迫切左外连接或迫切内连接查询缓存方式,减少select语句的数目,降低访问数据库的频率。

2.使用延迟加载策略方式避免加载多余的不需要访问的数据。

3.使用Query接口的iterator()方法减少select语句中的字段,从而降低访问数据库的数据量。

解析:第一次使用list()方法查询时,Hibernate从数据库查询Emp,对象,把所有的Emp对象放入Session缓存中,第二次使用list()查询shi2,Hibernate仍然从数据库查询Emp对象,而不是从Session缓存中获取Emp对象。

HQL优化:

HQL优化是Hibernate程序性能优化的一个方面,HQL的语法与SQL非常相似。HQL是基于SQL的,只是增加了面向对象的封装。如果抛开HQL同Hibernate本身一些缓存机制的关联,HQL的优化技巧同SQL的优化技巧一样。在编写HQL时,需注意以下几个原则:

(1)避免or操作的使用不当

(2)避免使用not

(3)避免使用like的特殊形式,例如 “%”或者”_”开头

(4)避免having字句

(5)避免distinct

(6)索引在以下情况下失效,应注意使用

1.只要对字段使用函数,该字段的索引将不起作用,如substring(aa,1,2)=’xx’

2.只要对字段进行计算,该字段的索引将不起作用,如Price+10

三批量处理数据
批量处理数据是指在一个事务场景中处理大量数据。在应用程序中难以避免进行批量操作,Hibernate提供了一下方式进行批量处理数据。

1.使用HQL进行批量操作 数据层面 executeUpdate()

1.使用HQL进行批量操作

HQL可以查询数据,也可以批量插入、更新和删除数据。HQL批量操作实际上直接在数据库中完成,处理的数据不需要加载到 Session缓存中。使用Query接口的executeUpdate()方法执行用于插入、更新和删除的HQL语句。

01批量插入数据

@Test
    //03.HQL 批量添加
    public void multiInsertTest(){
        String hql="insert into Dept(deptName) select d.deptName||d.deptNo from Dept d where d.deptNo>0";
        session.createQuery(hql).executeUpdate();
    }

02.批量更新数据  @Test
    //03.HQL 批量修改
    public void multiUpdateTest(){
        String hql="update Dept set deptName=:name where deptNo>2";
        session.createQuery(hql).setParameter("name","财务部").executeUpdate();
    }

03.批量删除

@Test
    //03.HQL 批量删除
    public void multiDeleteTest(){
        String hql="delete from Dept d where d.deptNo>:deptNo";
        session.createQuery(hql).setParameter("deptNo",20).executeUpdate();
    }

2.使用JDBC API进行操作。数据库层面

在Hibernate应用中使用JDBC API批量执行插入、修改和删除语句时,需要使用Session的doWork(Work work)方法执行Work对象指定的操作,即调用Work对象的execute()方法。Session把当前使用的数据库连接传给execute()方法,执行持久化操作。

@Test
    //04.JDBC API 批量修改
    public void insertTest(){
        Work work=new Work() {
            public void execute(Connection connection) throws SQLException {
                PreparedStatement ps = connection.prepareStatement("update DEPTY2163Session  set deptName='业务部'where DEPTNO>?");
                ps.setInt(1,1);
                ps.executeUpdate();
            }
        };
        //session
        session.doWork(work);
    }

注意:该方式使用的连接依然是最初的连接对象,并且命令对象依然是根据连接创建的,注意这里是SQL语句,不是HQL语句

3。使用Session 进行操作 会进缓存。

使用Session对象也可以进行批量操作。使用Session对象处理大量持久化对象,需及时从缓存中清空已经处理完毕并且不会再访问的对象。可以在处理完成一个对象或小批量对象后,调用flush()方法强制同步缓存和数据库,然后调用clear()方法清空缓存。

//05.Session 方案 进入缓存
    @Test
    public void insertUseSessionTest() {
        Emp emp=null;
        for (int i = 0; i < 100; i++) {
            emp=new Emp(i, "emp"+i);
            session.save(emp);
            if (i%30==0) {
                session.flush();
                session.clear();
            }
        }
    }

HQL连接查询的更多相关文章

  1. Hibernate批量处理数据、HQL连接查询

    一.批量处理操作 批量处理数据是指在一个事务场景中处理大量数据.在应用程序中难以避免进行批量操作,Hibernate提供了以下方式进行批量处理数据: (1)使用HQL进行批量操作     数据库层面 ...

  2. HQL连接查询和注解

    HQL连接查询和注解 一:HQL连接查询 各种连接查询: 内连接:inner join或join From Entity inner [inner] join [fetch] Entity.prope ...

  3. 【学习笔记】Hibernate HQL连接查询和数据批处理 (Y2-1-7)

    HQL连接查询 和SQL查询一样 hql也支持各种链接查询 如内连接 外连接 具体如下 左外连接 left (outer) join 迫切左外连接 left (outer) join fetch 右外 ...

  4. Hibernate批量处理数据、[HQL连接查询]

    一.批量处理操作 批量处理数据是指在一个事务场景中处理大量数据.在应用程序中难以避免进行批量操作,Hibernate提供了以下方式进行批量处理数据: (1)使用HQL进行批量操作 数据库层面 (2)使 ...

  5. HQL的内连接查询

    /** * HQL的内连接查询 * String hql="from Customer c inner join fetch c.linkmans"; */ @Test publi ...

  6. hibernate-HQL连接查询

    和SQL查询一样,HQL也支持各种各样的连接查询, 如内连接.外连接. 实例: package Test; import static org.junit.Assert.*; import java. ...

  7. hibernate 实现多表连接查询(转载)

    http://www.cnblogs.com/lihuiyy/archive/2013/03/28/2987531.html 为了方便,直接粘过来,方便查看.不收藏了 Hibernate主要支持两种查 ...

  8. hql 关联查询

    HQL 带的连接语句只能是实体与 该实体的属性 进行连接 其意义就是为了优化(通过延迟加载查询关联的属性)需要进行配置 from A left join A.B where (b.flag is nu ...

  9. 一步步学习NHibernate(9)——连接查询和子查询(1)

    请注明转载地址:http://www.cnblogs.com/arhat 在前几章中,我们把HQL的基本查询学习了一下,但是只有基本查询很显然不能满足我们的需求,那么就需要一下复杂查询比如" ...

随机推荐

  1. ISP和IAP

    ISP(在系统编程)是一种不依赖于单片机自身软件的程序下载方式,特点是不需要从电路板上取下单片机,通过某种方式使单片机进入ISP模式,开放编程接口,由其使用的计算机将新的程序代码写入到存储器内.我们平 ...

  2. 51nod算法马拉松 contest7

    A题 链接:http://www.51nod.com/contest/problem.html#!problemId=1417 推荐链接:http://blog.csdn.net/a837199685 ...

  3. TcpView 查看端口的小工具(推荐)

    介绍: TCPView是一个Windows程序,将显示你的详细清单的所有TCP和UDP端点在您的系统,包括拥有进程名称,远程地址和状态的TCP连接. 打开下面的链接就可以下载了. https://te ...

  4. INC函数

    1.inc(integer) inc(a)等于a:=a+1; 例: i := 100; inc(i); 结果:i等于101 2.inc(integer,integer) inc(a,b)等于a:=a+ ...

  5. S3C2440的RTC解析

    位二-十进制交换码(BCD)值数据给CPU.这些数据包括年.月.日.星期.时.分和秒的时间信息.RTC单元工作在外部32.768kHz晶振并且可以执行闹钟功能 实时时钟模块保存的数据是DCD码形式. ...

  6. 360路由器设置网段ip

    路由器设置->高级设置->修改路由器地址

  7. 转:HTTPS 升级指南

    上一篇文章我介绍了 HTTP/2 协议 ,它只有在 HTTPS 环境才会生效. 为了升级到 HTTP/2 协议,必须先启用 HTTPS.如果你不了解 HTTPS 协议(学名 TLS 协议),可以参考我 ...

  8. webstorm 激活码

    WebStorm 2016 最新版激活(activation code方式) 注册时,在打开的License Activation窗口中选择“activation code”,在输入框输入下面的注册码 ...

  9. 获取IIS版本

    近日,有一项目要分别获取iis6.0和7.5,然后对进程进行操作~ 研究良久,有以下办法获取iis版本. 代码: DirectoryEntry getEntity = new DirectoryEnt ...

  10. java名词解释,让你更好理解

    Java 开发工具包 (JDK) Java开发工具包是Java环境的核心组件,并提供编译.调试和运行一个Java程序所需的所有工具,可执行文件和二进制文件.JDK是一个平台特定的软件,有针对Windo ...