- 浏览: 93843 次
- 性别:
- 来自: 深圳
文章分类
最新评论
Criteria:
Criteria criteria = session.createCriteria(User.class);
1)criteria.add(Restrictions.gt("age", new Integer(20)));
2)criteria.add(Restrictions.lt("age", new Integer(40)));
3)criteria.add(Restrictions.or(Restrictions.eq("age", new Integer(20)), Restrictions.isNull("age")));
crit.add(Restrictions.ilike(
"name"
,
"1"
, MatchMode.END));
//
// ilike的i即ignore之意,所以这里查询出englishName"Optima?XL?100K?Ultracentrifuge"(忽略大小写)的记录
4)criteria.add(Restrictions.sqlRestriction("{alias}.name LIKE (?)", "cater%", Hibernate.STRING));
5) Integer[] ages = {new Integer(20), new Integer(40)};
Type[] types = {Hibernate.INTEGER, Hibernate.INTEGER};
criteria.add(Restrictions.sqlRestriction("{alias}.age BETWEEN (?) AND (?)", ages, types));
6) criteria.setFirstResult(51);
criteria.setMaxResult(50);
7) 统计表rowCount()、count()、max()、min()、countDistinct()
criteria.setProjection(Projections.avg("age"));
8)分组20,20,25,30 à 20.25.30
criteria.setProjection(Projections.groupProperty("age"));
9)结合统计分组
ProjectionList projectionList = Projections.projectionList();
projectionList.add(Projections.groupProperty("age"));
projectionList.add(Projections.rowCount());
Criteria criteria = session.createCriteria(User.class);
criteria.setProjection(projectionList);
10) Query Criteria Id: data type Long
projectionList.add(crit.add( Expression.idEq(
11111L
) );
11) Query Criteria Id: Not Equal
crit.add( Expression.ne(
"name"
,
"noName"
) );
)
12)
crit.setProjection(Projections.rowCount());
13
)
这
是
显
示不重
复记录
criteria.setResultTransformer(criteria.DISTINCT_ROOT_ENTITY);
List users = criteria.list();
Restrictions的幾個常用限定查詢方法如下表所示:
方法 |
說明 |
Restrictions.eq |
等於 |
Restrictions.allEq |
使用Map,使用key/value進行多個等於的比對 |
Restrictions.gt |
大於 > |
Restrictions.ge |
大於等於 >= |
Restrictions.lt |
小於 < |
Restrictions.le |
小於等於 <= |
Restrictions.between |
對應SQL的BETWEEN子句 |
Restrictions.like |
對應SQL的LIKE子句 |
Restrictions.in |
對應SQL的in子句 |
Restrictions.and |
and關係 |
Restrictions.or |
or關係 |
Restrictions.sqlRestriction |
SQL限定查詢 |
HQL(Hibernate Query Language)
PS:
1:HOL是不区分大小写的,但名称是区分大小写的.
2:如果User類別提供有適當的建構方法,則可以在使用HQL時直接指定新建一個物件傳回
Query query = session.createQuery("select new User(user.name, user.age) from User as user");
3. 如果試圖使用Session的saveOrupdate()方法,則會新增一筆資料而不是更新原有的資料。
4. 還可以結合having子句,例如只將平均大於20的資料分組顯示出來:
Query query = session.createQuery("select user.sex, avg(user.age) from User user group by user.sex having avg(user.age) > 20");
5. 更新与删除的时候
Session session = sessionFactory.openSession();
Transaction tx= session.beginTransaction();
Query query = session.createQuery("update User set name='momor' where name='bbb'");
query.executeUpdate();
tx.commit();
session.close();
Hibernate:HQL/QBC查询语言比较的用法
Hib的检索方式
1'导航对象图检索方式。通过已经加载的对象,调用.iterator()方法可以得到order对象
如果是首次执行此方法,Hib会从数据库加载关联的order对象,否则就从缓存中得到。
2'OID检索方式。通过session的get,load方法知道了OID的情况下可以使用
3'HQL检索方式。使用面向对象的HQL查询语句session的find方法利用HQL来查询
4'QBC检索方式。利用QBCAPI来检索它是封装了基于字符串的查询语句
5'本地的SQL检索方式。使用本地数据库的SQL查询语句Hib会负责把检索到的JDBC结果集映射为持久化对象图。
五种检索方式的使用场合和特点:
HQL : 是面向对象的查询语言,同SQL有些相似是Hib中最常用的方式。
查询设定各种查询条件。
支持投影查询,检索出对象的部分属性。
支持分页查询,允许使用having和group by
提供内制的聚集函数,sum(),min(),max()
能调用用户的自定义SQL
支持子查询,嵌入式查询
支持动态绑定参数
建议使用Query接口替换session的find方法。
Query Q = session.createQuery("from customer as c where c.name = :customerName" + "and c.age = :customerAge");
query.setString ("customerName" , "tom");
query.setInteger("customerAge" , "21");
list result = query.list();
QBC : QBCAPI提供了另一种方式,主要是Criteria接口、Criterion接口和Expression类
Criteria criteria = session.createCriteria(customer.class);
Criterion criterion1 = Expression.like("name","t%");
Criterion criterion2 = Expression.eq("age",new Integer(21));
Critera = criteria.add(criterion1) ;
Critera = criteria.add(criterion2) ;
list result = criteria.list();
或是: list result = session.createCriteria(Customer.class).add(Expression.eq("this.name","tom")).list();
SQL : 采用HQL和QBC检索时,Hib生成SQL语句适用所有数据库。
Query query = session.createSQLQuery("select {c.*} from customers c where c.name like : customername " + "and c.age = :customerage","c",customer.calss);
query.setString("customername","tom");
query.setInteger("customerage","21");
list result = query.list();
/////////////多态查询
HQL :session.createQuery("from employee");
QBC :session.createCriteria(employee.class);
HQL : session.createQuery("from hourlyEmployee");
QBC : session.createCriteria(hourlyEmployee.class);
下面的HQL查询语句将检索出所有的持久化对象:
from java.lang.Object ;
from java.io.serializable ;
////////////查询的排序
1'查询结果按照客户姓名升序排列:
HQL :
Query query = session.createQuery ("from customer c order by c.name");
QBC :
Criteria criteria = session.createCriteria(customer.class);
criteria.addOrder(order.asc("name"));
HQL :
Query query = session.createQuery ("from customer c order by c.name asc , c.age desc");
QBC :
Criteria criteria = session.createCriteria(customer.class);
criteria.addOrder(order.asc ("name"));
criteria.addOrder(order.desc("age"));
import net.sf.hibernate.pression.Order
import mypack.Order
...........
Criteria criteria = session.createCritria (mypack.Order.class);
criteria.addOrder(net.sf.hibernate.Order.asc("name"));
///////////HQL语句的参数绑定Query接口提供了绑定各种Hib映射类型的方法。
setBinary()
setString()
setBoolean()
setByte()
setCalendar()
setCharacter()
setDate()
setDouble()
setText()
setTime()
setTimestamp()
setEntity()//把参数与一个持久化类的事例绑定lsit result = session.createQuery("from order o where o.customer = :customer").setEntity("customer" , customer).list ;
setParameter()//绑定任意类型的参数
setProperties()//把命名参数与一个对象的属性值绑定 Query query = session.createQuery("from customer c where c.name =: name " + "and c.age =:age" );
Query.setProperties(customer);
发表评论
-
Hibernate Validator 实例
2008-06-18 11:21 5718在项目的业务属性中,你是不是要经常验证属性的取值范围呢. 想要 ... -
hibernate Annotations 实例
2008-06-18 11:16 2885从 hbm.xml 到 Annotations 任何获得Ma ... -
HibernateUtilSimple
2008-06-17 10:14 889package org.hibernate.auction.p ... -
HibernateUtil
2008-06-17 10:12 3391package org.hibernate.auction.p ... -
Hibernate的缓存机制介绍
2008-06-16 16:51 947缓存是介于应用程序和 ... -
hibernate常用语句
2008-06-16 16:50 1076Session Session lifecycle begin ... -
hibernate 配置
2008-06-16 16:49 1525第 4 章 配置 由于Hibernate是为了 ... -
对象/关系数据库映射基础
2008-06-16 16:47 1563对象和关系数据库之间的映射通常是用一个XML文档( ... -
集合类(Collections)映射
2008-06-16 16:45 977(译者注:在阅读本章的时候,以后整个手册的阅读过程中,我们都会 ... -
Hibernate包作用详解
2008-06-16 16:43 795Hibernate一共包括了23个ja ... -
HibenateMinute(一)
2008-06-16 16:39 918@ Hibernate3.0 àJBOSS @ ORM à「对 ... -
HibenateMinute(三)
2008-06-16 16:35 919hiberate缓存 一般而言,ORM的数据缓存应包含如下几个 ... -
Hibernate关系映射
2008-06-16 16:34 1015第 8 章 关联关系映射 8.1. 介绍 ... -
Hibernate对象共事
2008-06-16 16:32 1090第 11 章 与对象共 ... -
hibernate查询语言
2008-06-16 16:29 2145第 14 章 批量处理(Batch processing ... -
hibernate提升性能
2008-06-16 16:25 1013第 20 章 提升性能 20.1. 抓 ... -
hibernate工具箱指南
2008-06-16 16:23 1434第 21 章 工具箱指南 可以通过一系列Eclip ... -
hibernate体系结构
2008-06-16 16:20 1741第 3 章 体系结构(A ...
相关推荐
matplotlib-3.6.3-cp39-cp39-linux_armv7l.whl
numpy-2.0.1-cp39-cp39-linux_armv7l.whl
基于springboot个人公务员考试管理系统源码数据库文档.zip
onnxruntime-1.13.1-cp310-cp310-win_amd64.whl
基于springboot的西山区家政服务网站源码数据库文档.zip
Linux环境下,关于C++静态库的封装和调用代码。 TestLib是库目录。 TestLibCall是调用库的目录。
基于springboot软件技术交流平台源码数据库文档.zip
numpy-1.20.1-cp39-cp39-linux_armv7l.whl
ASP.NET酒店管理系统源码(WPF) 一、源码特点 采用WPF进行开发的酒店管理系统源码,界面相当美观,功能齐全 二、菜单功能 1、预订登记:可选择入住时间、离店时间、所在城市、证件类型,保存、删除、查询、返回 2、住宿结算:新增入住、保存、删除、查询、返回 3、今日盘点:查询、返回 4、查询统计: 5、房间管理:增加房间类型、删除类型、增加房间、删除房间、保存、返回 6、用户管理:增加用户、删除用户、保存、返回 7、系统配置:基本功能 8、显示当前系统时间等功能的实现
坠落的天空小游戏图片和代码
论文描述:该论文研究了某一特定领域的问题,并提出了新的解决方案。论文首先对问题进行了详细的分析和理解,并对已有的研究成果进行了综述。然后,论文提出了一种全新的解决方案,包括算法、模型或方法。在整个研究过程中,论文使用了合适的实验设计和数据集,并进行了充分的实验验证。最后,论文对解决方案的性能进行了全面的评估和分析,并提出了进一步的研究方向。 源码内容描述:该源码实现了论文中提出的新的解决方案。源码中包含了算法、模型或方法的具体实现代码,以及相关的数据预处理、实验设计和性能评估代码。源码中还包括了合适的注释和文档,以方便其他研究者理解和使用。源码的实现应该具有可读性、可维护性和高效性,并能够复现论文中的实验结果。此外,源码还应该尽可能具有通用性,以便在其他类似问题上进行进一步的应用和扩展。
环境说明: 开发语言:python Python版本:3.6.8 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:pycharm
基于springboot高校学术交流平台源码数据库文档.zip
onnxruntime-1.16.2-cp310-cp310-win_amd64.whl
基于springboot+vue的实践性教学系统源码数据库文档.zip
基于springboot的校园二手物品交易系统源码数据库文档.zip
numpy-1.23.5-cp39-cp39-linux_armv7l.whl
bimdata_api_client-4.0.2-py3-none-any.whl
环境说明: 开发语言:PHP 框架:原生php/thinkphp5 服务器:Apache 数据库:mysql 5.7(一定要5.7版本) 数据库工具:Navicat 11 运行软件:小皮phpStudy
基于SpringBoot的中老年人文化活动平台源码数据库文档.zip