Hibernate 查询
来源:互联网 发布:备孕前准备 知乎 编辑:程序博客网 时间:2024/06/04 19:42
使用get方法
使用get方法通过持久类名和ID号查找一个对象Stu instance = (Stu) getsession() .get(“com.lovo.po.Stu”, id);
使用createQuery方法
使用createQuery指定查询条件
String queryString = "from Stu as model where model." + propertyName + "= ?";Query queryObject = getSession().createQuery(queryString); queryObject.setParameter(0, value);
Hibernate语言查询
Hibernate Query Language,HQL
完全面向对象的查询语句
查询功能非常强大
具备继承、多态和关联等特性
Hibernate官方推荐使用HQL进行查询。
HQL
HQL用面向对象的方式生成SQL
以类和属性来代替表和数据列
支持多态
支持各种关联
减少了SQL的冗余
HQL支持所有的关系数据库操作
连接(joins,包括Inner/outer/full joins),笛卡尔积(cartesian products)
投影(projection)
聚合(Aggregation,max, avg)和分组(group)
排序(Ordering)
子查询(Subqueries)
SQL函数(SQL function calls)
使用HQL
对表和字段的操作转化为对对象和属性的操作
HQL查询非常类似于标准SQL查询
完整的HQL语句形势如下:
Select/update/delete…… from …… where …… group by …… having …… order by …… asc/desc
update/delete为Hibernate3中所新添加的功能
实体查询
String hql=”from User(持久类) user(别名) ”;List list=session.CreateQuery(hql).list();
执行结果是,查询出User实体对象所对应的所有数据,而且将数据封装成User实体对象,并且放入List中返回
Hibernate的实体查询存在着对继承关系的判定 ,查询超类会检索出所有超类和子类类型实体对象所对应的数据
与标准SQL语句相似,可以在HQL语句中使用where字
from User user where user.age=20;from User user where user.age between 20 and 30;from User user where user.age in(20,30);from User user where user.name is null;from User user where user.name like ‘%zx%’;from User user where (user.age%2)=1;from User user where user.age=20 and user.name like ‘%zx%’;
实体的更新和删除
Hibernate3中对更新和删除提供灵活和更具效率的解决办法
Transaction trans=session.beginTransaction();String hql=”update User user set user.age=20 where user.age=18”;Query queryupdate=session.createQuery(hql);int ret=queryupdate.executeUpdate();trans.commit();
类似的方式来完成delete操作
Transaction trans=session.beginTransaction();String hql=”delete from User user where user.age=18”;Query queryupdate=session.createQuery(hql);int ret=queryupdate.executeUpdate();trans.commit();
分组与排序
Order by子句 ,可以通过asc或者desc关键字指定排序方式 ,默认的排序方式为asc
from User user order by user.name asc,user.age desc;
Group by子句与统计查询
String hql=”select count(user),user.age from User user group by user.age having count(user)>10 ”;List list=session.createQuery(hql).list();
标准的SQL聚集函数都可以在HQL语句中使用,比如:count(),sum(),max(),min(),avg()等
- hibernate查询
- Hibernate 查询
- hibernate查询
- HIbernate 查询
- HIbernate 查询
- HIbernate 查询
- HIBERNATE查询
- Hibernate查询
- Hibernate查询
- Hibernate查询
- Hibernate 查询
- HIbernate查询
- Hibernate查询
- Hibernate查询
- Hibernate查询
- Hibernate 查询
- hibernate查询
- hibernate 查询
- 兄弟连HTML5——10.11.12.13.14.15canvas实例3——在线画图工具——功能介绍和页面布局
- 回调函数
- nginx thinkphp
- 设计模式详解(总纲)
- 相对布局和网格布局
- Hibernate 查询
- 《Sphinx权威指南》 - Sphinx入门
- Java IO
- 用于分配空间的函数malloc、calloc、realloc
- 各位好啊 加入了CSDN这个大家庭啊
- java运行jar文件中某个类
- 在python中,获取用户输入信息
- solr5.5.0 中文分词<三>
- HTML5 FileReader 读取txt文件