浅谈Hibernate--Hibernate查询(Query Language) (转)

1.查询对象:Query有org.hibernate.query和javax.persistence.query,用法如下

如果按条件查找

2.占位符:比如下面的例子:min 和:max,和query.setParameter(key,value);

链式的也可以,同时这里setParameter("","")是会自动设置参数的值,如果知道传入的类型可以setInteger..

3.分页效果
通过query.setMaxResult(n).setFirstResult(m)取出m~n之间的记录

setFirstResult(m):选择从第几行开始取,默认是row0
setMaxResult(n):决定取出多少条记录,默认是往后所有rows

和下面普通的ql语句实现一样

4.获取子属性
Query query=session.createQuery("from Score s where s.xxx.id=..")

同时也可以把临时对象取出来放到Object或者自己建立的辅助类里去
1.Query query=session.createQuery("select s.name,c.name from Student s,Course c where s.id=.. and c.id=..")
2.Query query=session.createQuery("select new VObj(s.name,c.name) from Student s,Course c where s.id=.. and c.id=..")

取出部分属性封装成一个新的对象是不可取的,最好完整的取出整个属性以保证他逻辑的关联性
如果要取出就这样取

5.单个对象匹配
如果你知道取出的是唯一的一个对象,那么就不用query.list(),要用query.uniqueResult();效率比较高

count(*)返回的是一个long类型

in

Group by
select avg(s.age) from Student group by s.col;

having
select count(*)  from Student s where group by s.col having count(*)>3;
空值Empty:下面是学生类(Student)中有Set<Course> courses属性(学生所选课程) 选出哪些选课为空的学生

Like: %多个 ; _ 一个

distinct

6.可以把QL语句放在一起,以便维护修改用@NamedQueries和@NamedQuery,调用的时候用session.getNamedQuery(QueryName)

7.使用数据库自身语言
如果用hql解决不了问题,那就用sql语言来解决,通过createSQLQuery()来搜索表,并用addEntity(xx.Class)转换成对象

当然这也可以用命名的Query

8.批量删除:通过query.executeQuery();return一个int类型,返回update和delete成功的行数

时间: 2024-10-07 00:50:41

浅谈Hibernate--Hibernate查询(Query Language) (转)的相关文章

浅谈:Hibernate中HibernateUtil工具类

首先我们需要知道为什么咱们要创建Hibernate工具类 一些固定而且经常使用的步骤我们期望做成一个工具类,以后再需要重复步骤时咱们仅需要引用此工具类就可以,从而避免了一直创建重复代码.比如加载数据库的驱动等,这里Hibernate中我们每个主程序都需要加载hibernate.cfg.xml文件.创建SessionFactory对象.创建Session对象.关闭session.这些都是固定化的步骤,因此我们将它们写在工具类HibernateUtil中,以后咱们直接引用此文件创建各对象即可,大大减

浅谈数据库联合查询

http://www.cnblogs.com/Candies/p/4142576.html 本文介绍以下内容: LFET JOIN.RIGHT JOIN.INNER JOIN.UNION.UNION ALL.FULL JOIN等! 测试数据(以下数据未经考证,非真实有效数据,仅作为本次学习的测试数据!) 全国大学排名TOP20 No. 校名 地区 校长 类型 1 北京大学 北京 周其凤 综合 2 清华大学 北京 顾秉林 理工 3 浙江大学 浙江 杨卫 综合 4 复旦大学 上海 杨玉良 综合 5

Unity3D 开发之shader教程(浅谈GPU渲染之shader language概述)

尊重他人智慧成果,欢迎转载,请注明作者 心若透明 地址  http://www.cnblogs.com/ubanck/p/4110618.html 在上一篇博客里,大致讲解了一下3D渲染的原理,即从一个简单的模型到渲染到屏幕的过程!其中提到了重要的坐标变换方式,说的不够清楚!今天来谈谈shader语言的执行过程 从硬件上讲,GPU内部有顶点着色器与片段着色器,从渲染管线来看,顶点着色器控制这顶点的坐标转换过程,片段着色器控制像素的颜色计算过程.顶点着色器将顶点转换完成,输入到片段着色器进行处理(

浅谈 T-SQL高级查询

之前我们简单的了解了增.删.改.查这几类T-SQL语法来操纵数据表,但是为了更方便快捷地完成大量任务,SQL Server 提供了一些内部函数,可以和SQL Server 的SELECT语句来联合使用,进行类型转换.日期处理.数学计算.实现系统功能.字符串在信息处理时有特殊的地位,几乎所有信息都需要转化成字符串才能正确显示,尤其是不同数据拼接起来显示的使用更加广泛.字符串之间使用"+"拼接 select '运维工程师' + '姓名'+'的基本工资是:'+ cast(基本工资 as va

Hibernate Query Language查询:

Hibernate Query Language查询: Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供了更加丰富的和灵活的查询特性,因此Hibernate将HQL查询方式立为官方推荐的标准查询方式,HQL查询在涵盖Criteria查询的所有功能的前提下,提供了类似标准SQL语句的查询方式,同时也提供了更加面向对象的封装.完整的HQL语句形势如下: Select/update/delete-- fro

常用HQL(Hibernate Query Language)查询

查询一个对象(实体类必须有一个不带参数的构造方法) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 @Test public void test01() {     Session session = null;     try {         session = HibernateUtil.openSession();         /**          * 对于HQL而言,都是基于对象进行查询的          */        

hql(Hibernate Query Language)

1.Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供了更加丰富的和灵活的查询特性,因此Hibernate将HQL查询方式立为官方推荐的标准查询方式,HQL查询在涵盖Criteria查询的所有功能的前提下,提供了类似标准SQL语句的查询方式,同时也提供了更加面向对象的封装.完整的HQL语句形式如下: Select/update/delete-- from -- where -- group by --

Hibernate更新部分字段浅谈

update语句是在Hibernate的Configuration的时候生成的,不能动态改变.为什么update的时候所有的属性都一起update,而不是只更新改变字段,其实这是一个比较值得探讨的问题. 如果想要做到只更新改变了的字段,必须做到两点:1.对PO的每个属性设置version进行状态跟踪2.update语句是动态生成的,在实际向数据库更新的时候,依次检查每个属性的version,决定哪些属性需要更新,动态构造update语句. 单单要做到上述第一点,就势必要给PO的操作带来沉重的负担

hibernate 中的query的分页查询

//方法描述:根据会员名称和页容量分页查询代理人 public List<HbUser> findUserByPage(int page,int pageSize, String userName)   throws Exception {  Session session = sessionFactory.getCurrentSession();  StringBuffer hql = new StringBuffer("from HbUser where isDelete = 0