Hibernate中createCriteria即QBC查询的详细用法

现在假设有一个Student类,内有id,name,age属性
String hql = "from Student s";
按照以前的做法,我们通常是
Query query = session.createQuery(hql);
或者要按照条件检索的话.
String hql = "from Student s where s.name like ‘王%‘"
Query query = session.createQuery(hql);
不用HQL而使用QBC的话,那么代码为:
Criteria criteria =session.createCriteria(Student.class);
Criterion criterion = Expression.like("name","王%");
这样还看不出来.那我们把检索条件加上年龄为22.
HQL:
String hql = "from Student s where s.name like ‘王%‘ and s.age= 22 ";
Query query = session.createQuery(hql);
List list = query.list();
QBC:
Criteria criteria =session.createCriteria(Student.class);
Criterion criterion1 = Expression.like("name","王%");
Criterion criterion2 = Expression.eq("age",newInteger(22));
criteria.add(criterion1).add(criterion2);
List list = criteria.list();

看上去烦琐很多.但是做过项目的人都知道,当一个模块业务逻辑发生改变的时候,往往要重写sql,最烦也是最讨厌的就是拿着别人的hql或者sql,两眼瞪的溜园找到底要修改什么地方呢?
如果使用QBC大大的增加了代码的可读性,以及可维护性.
需要注意的是null值
比如我们要查找姓名为null的Student对象时应该这么写
Criteria criteria =session.createCriteria(Student.class);
Criterion criterion = Expression.isNull("name");
criteria.add(criterion).list();
以及使用between...and的时候
Criteria criteria =session.createCriteria(Student.class);
Criterion criterion1 = Expression.ge("age",new Integer(20));//下限
Criterion criterion2 = Expression.le("age",new Integer(25));//上限
//这里也可以把上述两个条件添加到第三个条件里
Criterion criterion3 =Expression.and(criterion1,criterion2);
criteria.add(criterion3).list();
相当于from Student s where s.age between 20 and 25
等同于from Student s where s.age >= 20 and s.age <=25

下面是就HQL和QBC常用的查询条件做的比较
表达式含义                   HQL                   QBC
大于等于                     >=                    Expression.ge()
大于                           >                      Expression.gt()
小于等于                     <=                    Expression.le()
小于                           <                      Expression.lt()
等于                           =                      Expression.eq()
不等于                    <>或者!=               Expression.ne()

为空                         is null                  Expression.isNull()
不为空                      is notnull             Expression.isNotNull()
在指定范围内             betweenand          Expression.between()
不在指定范围             not betweenand    Expression.not(Expression.between())
属于某个集合                 in                    Expression.in()
不属于某个集合             notin                 Expression.not(Expression.in())
与                              and                   Expression.and()
或                               or                    Expression.or()
非                              not                   Expression.not()
模糊查询                      like                   Expression.like

1、创建一个Criteria实例 net.sf.hibernate.Criteria这个接口代表对一个特定的持久化类的查询。Session是用来制造Criteria实例的工厂。

Criteria crit = sess.createCriteria(Cat.class);

crit.setMaxResults(50);

List cats = crit.list();

2、缩小结果集范围 一个查询条件(Criterion)是net.sf.hibernate.expression.Criterion接口的一个实例。类net.sf.hibernate.expression.Expression定义了获得一些内置的Criterion类型。

List cats = sess.createCriteria(Cat.class)

.add( Expression.like("name", "Fritz%") )

.add( Expression.between("weight", minWeight, maxWeight))

.list();

表达式(Expressions)可以按照逻辑分组.

List cats = sess.createCriteria(Cat.class)

.add( Expression.like("name", "Fritz%") )

.add( Expression.or( Expression.eq( "age", new Integer(0) ), Expression.isNull("age")))

.list();

List cats = sess.createCriteria(Cat.class)

.add( Expression.in( "name",new String[]{"Fritz","Izi","Pk"}))

.add( Expression.disjunction()

.add( Expression.isNull("age") )

.add( Expression.eq("age", new Integer(0) ) )

.add( Expression.eq("age", new Integer(1) ) )

.add( Expression.eq("age", new Integer(2) ) ) ) )

.list();

有很多预制的条件类型(Expression的子类)。有一个特别有用,可以让你直接嵌入SQL。

List cats = sess.createCriteria(Cat.class)

.add( Expression.sql("lower($alias.name) like lower(?)", "Fritz%", Hibernate.STRING))

.list();  
其中的{alias}是一个占位符,它将会被所查询实体的行别名所替代。(原文:The {alias} placeholder with be replaced by the row alias of the queried entity.)

3、对结果排序 可以使用net.sf.hibernate.expression.Order对结果集排序.

List cats = sess.createCriteria(Cat.class)

.add( Expression.like("name", "F%")

.addOrder( Order.asc("name"))

.addOrder( Order.desc("age"))

.setMaxResults(50)

.list();

4、关联(Associations) 你可以在关联之间使用createCriteria(),很容易地在存在关系的实体之间指定约束。

List cats = sess.createCriteria(Cat.class)

.add( Expression.like("name", "F%")

.createCriteria("kittens")

.add( Expression.like("name","F%")

.list();

注意,第二个createCriteria()返回一个Criteria的新实例,指向kittens集合类的元素。 下面的替代形式在特定情况下有用。

List cats = sess.createCriteria(Cat.class)

.createAlias("kittens", "kt")

.createAlias("mate", "mt")

.add(Expression.eqProperty("kt.name", "mt.name"))

.list();

(createAlias())并不会创建一个Criteria的新实例。) 请注意,前面两个查询中Cat实例所持有的kittens集合类并没有通过criteria预先过滤!如果你希望只返回满足条件的kittens,你必须使用returnMaps()。

List cats = sess.createCriteria(Cat.class)

.createCriteria("kittens", "kt")

.add( Expression.eq("name", "F%") )

.returnMaps()

.list();

Iterator iter = cats.iterator();

while ( iter.hasNext())

{

Map map = (Map) iter.next();

Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);

Cat kitten = (Cat) map.get("kt");

}

5、动态关联对象获取(Dynamic association fetching) 可以在运行时通过setFetchMode()来改变关联对象自动获取的策略。

 

List cats = sess.createCriteria(Cat.class)

.add( Expression.like("name", "Fritz%") )

.setFetchMode("mate", FetchMode.EAGER)

.list();

这个查询会通过外连接(outer join)同时获得 mate和kittens。

6、根据示例查询(Example queries) net.sf.hibernate.expression.Example类许你从指定的实例创造查询条件。

Cat cat = new Cat();

cat.setSex(‘F‘);

cat.setColor(Color.BLACK);

List results = session.createCriteria(Cat.class)

.add( Example.create(cat) )

.list(); 
版本属性,表示符属性和关联都会被忽略。默认情况下,null值的属性也被排除在外。 You can adjust how the Example is applied. 你可
以调整示例(Example)如何应用。 Example example = Example.create(cat) .excludeZeroes() //exclude zero valued properties

.excludeProperty("color") //exclude the property named "color" .ignoreCase() //perform case insensitive string comparisons

.enableLike(); //use like for string comparisons

List results = session.createCriteria(Cat.class)

.add(example)

.list(); 
你甚至可以用示例对关联对象建立criteria。 List results = session.createCriteria(Cat.class) .add(Example.create(cat) )

.createCriteria("mate") .add(Example.create(cat.getMate())) .list();

参考代码如下:

[java] view plain copy

    1. String[] aa = new String[2];
    2. List results = getSession().createCriteria(
    3. "base.database.entity.Menu")
    4. .add(Example.create(instance))
    5. .add(Restrictions.between("date",new Date(),new Date()))
    6. .add(Restrictions.or(Expression.eq("flg", "S"), Expression.eq("FLG", "D")))
    7. .add(Restrictions.in("flg", aa))
    8. .addOrder(Order.asc("menuOrder"))
    9. .list();
    10. add(Projections.groupProperty("color"))
时间: 2024-12-19 15:31:21

Hibernate中createCriteria即QBC查询的详细用法的相关文章

Hibernate中createCriteria即QBC查询的详细用法 .Hibernate中createCriteria即QBC查询的详细用法 .

现在假设有一个Student类,内有id,name,age属性String hql = "from Student s";按照以前的做法,我们通常是Query query = session.createQuery(hql);或者要按照条件检索的话.String hql = "from Student s where s.name like '王%'"Query query = session.createQuery(hql);不用HQL而使用QBC的话,那么代码为

Hibernate中createCriteria(QBC)查询的用法

现在假设有一个Student类,内有id,name,age属性 String hql = "from Student s"; 按照以前的做法,我们通常是 Query query = session.createQuery(hql); 或者要按照条件检索的话. String hql = "from Student s where s.name like '王%'" Query query = session.createQuery(hql); 不用HQL而使用QBC的

转——JAVA中calendar,date,string 的相互转换和详细用法

package cn.outofmemory.codes.Date; import java.util.Calendar; import java.util.Date; public class CalendarDemo { public static void main(String[] args) { Calendar calendar=Calendar.getInstance(); calendar.setTime(new Date()); System.out.println("现在时间

使用SQLQuery 在Hibernate中使用sql语句

session.createSQLQuery.转载 对原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行Session.createSQLQuery()获取这个接口.下面来描述如何使用这个API进行查询. 1.标量查询(Scalar queries) 最基本的SQL查询就是获得一个标量(数值)的列表. sess.createSQLQuery("SELECT * FROM CATS").list();sess.createSQLQuery("SELECT ID,

Hibernate中get()和load()的区别

Hibernate中根据Id单条查询获取对象的方式有两种,分别是get()和load(),来看一下这两种方式的区别. 1. get() 使用get()来根据ID进行单条查询: User user=session.get(User.class, "1"); 当get()方法被调用的时候就会立即发出SQL语句: Hibernate: select user0_.ID as ID1_1_0_, user0_.CREATETIME as CREATETI2_1_0_, user0_.UPDAT

【hibernate】Hibernate中get()和load()的区别

Hibernate中根据Id单条查询获取对象的方式有两种,分别是get()和load(),来看一下这两种方式的区别. 1. get() 使用get()来根据ID进行单条查询: 1 User user=session.get(User.class, "1"); 当get()方法被调用的时候就会立即发出SQL语句: 1 2 3 4 5 6 7 8 9 10 11 Hibernate:     select         user0_.ID as ID1_1_0_,         use

Hibernate 中出现 users is not mapped 问题

Hibernate 中出现 users is not mapped 问题: 解答:HQL语句中表名应该是ORM映射的类名,所以应该改成:  (如果是用注解生成实体类,那就是注解的那个类)String sql = "select u.password from User u where u.username='" +user.getUsername()+ "'"; User.hbm.xml:<class name="com.lian.bean.User

Hibernate中的QBC查询

QBC 查询方式(Query By Criteria) public void testQBCQuery1(){ Criteria criteria=session.createCriteria(Student.class); List<Student> studentList=criteria.list(); Iterator it=studentList.iterator(); while(it.hasNext()){ Student s=(Student)it.next(); Syste

[原创]java WEB学习笔记92:Hibernate学习之路-- -QBC 检索和本地 SQL 检索:基本的QBC 查询,带 AND 和 OR 的QBC,统计查询,排序,分页

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------