【Hibernate】hql使用总结(下)

     上篇博客介绍了简单的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
    收藏
    觉得还不错? 一键收藏
  • 16
    评论
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值