【Hibernate】hql使用总结(下)

来源:互联网 发布:linux卸载subversion 编辑:程序博客网 时间:2024/04/28 13:57

     上篇博客介绍了简单的hql语句,简单属性查询,实体类查询,条件查询以及对原生sql的支持,这篇博客继续介绍hql语句。

一、外置命名查询

     映射文件中使用<query>标签,并为该标签添加name属性,将字符串添加到程序中<![CDATA[]]>中,用session.getNamedQuery得到hql查询串。外置命名查询将查询语句放到映射文件中,这样在程序中都可以查询使用该字符串。

<hibernate-mapping><class name="com.hibernate.Student" table="t_student"><id name="id"><generator class="native"/></id><property name="name"/><property name="createTime"/><many-to-one name="classes" column="classesid"/></class><query name="queryStudent"><![CDATA[select s from Student s where s.id <?]]></query></hibernate-mapping>

程序中代码:

List students = session.getNamedQuery("queryStudent").setParameter(0, 10).list();for (Iterator iter=students.iterator(); iter.hasNext();) {Student student = (Student)iter.next();System.out.println(student.getName());}


二、查询过滤器

    查询过滤器可以对查询的内容进行过滤,在映射文件中定义过滤器参数,在类的映射文件中使用过滤器参数,在程序中启用过滤器为过滤器参数赋值。下面的例子是使用过滤器,指定id的值小于参数:myid的部分

<hibernate-mapping><class name="com.bjpowernode.hibernate.Student" table="t_student"><id name="id"><generator class="native"/></id><property name="name"/><property name="createTime"/><many-to-one name="classes" column="classesid"/><filter name="testFilter" condition="id < :myid"></filter></class><filter-def name="testFilter"><filter-param type="integer" name="myid"/></filter-def></hibernate-mapping>

程序中代码:

             session.enableFilter("testFilter").setParameter("myid", 10);List students = session.createQuery("from Student").list();for (Iterator iter=students.iterator(); iter.hasNext();) {Student student = (Student)iter.next();System.out.println(student.getName());}

三、分页查询

分页查询在项目中经常会用到,setFirstRestlt()从0开始,setMaxResults():每页显示的记录数。实例如下:

                List students = session.createQuery("from Student").setFirstResult(1).setMaxResults(2).list();for (Iterator iter=students.iterator(); iter.hasNext();) {Student student = (Student)iter.next();System.out.println(student.getName());}

四、对象导航查询

    听到导航我们一定很熟悉,之前做.netITOO的时候我们经常会用到导航属性,如果两个表存在主外键联系,这个表可以直接“.”另一个表就可以读取另一个表的属性名称。

List students = session.createQuery("from Student s where s.classes.name like '%2%'").list();

五、连接查询

  连接查询主要是内连接和外连接,我们SQL语句经常会用到的,其中外连接包括左连接和右连接,

1.内连接

查询的结果是笛卡尔积,如果A是学生,B是班级,那么AB的笛卡尔积就是所有学生可能呆的班级的情况。内连接使用join关键字

List students=session.createQuery("select s.name,c.name from Student s join s.classes c").list();

2.外连接

分为左连接和右连接,左连接强调左面如果左面是学生的话,那么它就把所有的学生都查出来了,即使这个学生不属于任何一个班级也会查询出来。右连接强调右面的,如果右面是班级的话,那么会显示所有的班级,没有学生也出来。下面是左连接例子:

List students = session.createQuery("select c.name, s.name from Student s left join s.classes c").list();


六、统计查询

项目中经常会用到统计数量的需求,这时会用到统计查询,简单示例如下:

String hql = "select c.name, count(s) from Classes c join c.students s group by c.name order by c.name";List students = session.createQuery(hql).list();for (int i=0; i<students.size(); i++) {Object[] obj = (Object[])students.get(i);System.out.println(obj[0] + ", " + obj[1]);}

七、DML风格的操作

Data Manipulate Language(数据操作语言),看下面的例子,如果看这个代码,我们可能才打印出来的是王五,其实不是,还是远来的数据,李四,因为数据库表中更新了,但是缓存没有更新,所以我们一般不建议使用,除非有必须,比如遇到性能问题。

Student student = (Student)session.get(Student.class, 1);//数据库表中更新了,但缓存不更新//所以一般不建议使用,除非有必须,如遇到性能问题session.createQuery("update Student s set s.name=? where s.id<?").setParameter(0, "王五").setParameter(1, 5).executeUpdate();//student = (Student)session.load(Student.class, 1);student = (Student)session.get(Student.class, 1);System.out.println("student.name=" + student.getName());

小结:

      到这里基本的hql语句就总结完了。基本的可能是这样,更多的需要我们在项目实践中综合使用。接下来的博客会继续介绍hibernate,这段时间发现喜欢上了总结。

1 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 喝醉酒想吐吐不出来怎么办 凉了胃怎么办喝什么药 生宝宝后屁股扁了怎么办 屁股又宽又扁怎么办 烫伤一年多色差没有恢复怎么办 上古卷轴5不能动怎么办 上古卷轴ol卡死怎么办 小妹妹这么骚长大了怎么办 同事借钱忘了还怎么办 怀了二胎想离婚怎么办 如果闺蜜疏远了怎么办 考上博士但是硕士要延期怎么办 硕士延期也不能毕业怎么办 硕士论文工作量太少被延期了怎么办 竞彩足球比赛延期中断怎么办? 竞彩足球输了怎么办 讯飞语音不兼容百度怎么办 虎牙直播不兼容语音怎么办 为什么手机打开游戏就死机怎么办 2007cad打开时时死机怎么办 手机qq总是无响应怎么办 英雄联盟登录服务器未响应怎么办 苹果7p照相死机怎么办 小米手机qq打不开怎么办啊 电脑qq老是闪退怎么办 微信摄像卡住了怎么办 电脑打开应用程序没反应怎么办 宇飞来手机锁了怎么办 宇飞来手机忘记密码怎么办 vivo手机突然开不了机怎么办 苹果六关不了机怎么办 微信老是无响应怎么办 打游戏被骂了怎么办 微信运动跳转排行榜失败怎么办 小恩爱账号忘了怎么办 华为账号更换后游戏账号怎么办 注册游戏账号需要身份证怎么办 英雄联盟被裁决了怎么办 百度网盘密码重置不了怎么办 sap密码输入被锁怎么办 dnf二级密码错10怎么办