java中Criteria浅解

                                     Criteria Query

可以看作传统sql的对象化表示Criteria 可以由session创建。

先来一段小Demo:

TbItemParamExample example = new TbItemParamExample();
Criteria criteria = example.createCriteria();
criteria.andItemCatIdEqualTo(cid);


Criteria ct= session.createCriteria(TUser.class);Criteria中可以增加查询条件
ct.add(Expression.eq("name","Erica"));
ct.add(Expression.eq("sex",new Integer(1)));Criteria中增加的查询条件可以由表达式对象创建
Expression.eq(对象属性名,对象属性值);查询条件通过Criteria的add方法加入。表达式对象的方法有:
eq 等于,第一个参数是对象属性,第二个参数是值
allEq 参数为一个Map对象,相当于多个eq的叠加
gt 大于
ge 大于等于
lt <
le <=
between 在两个值之间Expression.between("age",new Integer(10),new Integer(20));
like like查询
in in查询
eqProperty 用于比较两个对象的属性的值是否相等
gtProperty
geProperty
ltProperty
leProperty
and and方法可以嵌套Expression对象,用于and关系
or 同上
如:Expression.or(
Expression.eq("name","hulei"),
Expression.eq("name","jane")
);
sql 作为Expression对象的补充,本方法提供对原生sql的支持***注意,在Hibernate3中,引入了Restrictions类作为Expression的替代,以后的版本,不再推荐使用Expression。
但是,Restrictions类的使用方法和Expression的方法一致。注意,在查询条件中,Hibernate提供了一个Example查询,当查询条件比较多的时候,
可以用Example查询来简化代码,使用方法如下:
TUser user=new TUser();
user.setLoginName("hulei");
user.setPassword("hulei");
Criteria ct=session.createCriteria(TUser.class);
ct.add(Example.create(user));
return ct.list();
复合查询
Criteria查询可以嵌套Criteria来实现复合查询
如下:
Criteria ct=session.createCriteria(TUser.class);
Criteria ctAddress=ct.createCriteria("addresses");//这里是嵌套了一个Criteria查询,这里的addresses是TUser的属性
ctAddress.add(Expression.like("address","%shanghai%"));
List list=ct.list();

  • 14
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Java Criteria 对象是 Hibernate 框架用于创建查询条件的一种方式。它提供了一种类型安全、面向对象的查询方式,可以通过一个简单的 API 构建复杂的查询条件。 使用 Criteria 对象进行查询的一般步骤如下: 1. 首先,通过 Hibernate 的 Session 对象获取一个 CriteriaBuilder 对象,可以使用 Session 的 getCriteriaBuilder() 方法来获取。 2. 使用 CriteriaBuilder 对象创建一个 CriteriaQuery 对象,可以使用 CriteriaBuilder 的 createQuery() 方法来创建。CriteriaQuery 对象用于指定要查询的实体类和查询结果的类型。 3. 根据需要,可以在 CriteriaQuery 对象上添加各种查询条件、排序规则、分页信息等。 4. 通过 Session 的 createQuery() 方法执行查询,并传入 CriteriaQuery 对象。 5. 最后,通过 Query 的 getResultList() 方法获取查询结果。 以下是一个简单的示例代码,展示了如何使用 Criteria 对象进行查询: ```java Session session = sessionFactory.openSession(); CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder(); CriteriaQuery<User> criteriaQuery = criteriaBuilder.createQuery(User.class); Root<User> root = criteriaQuery.from(User.class); // 添加查询条件 Predicate condition = criteriaBuilder.equal(root.get("age"), 18); criteriaQuery.where(condition); // 执行查询 Query<User> query = session.createQuery(criteriaQuery); List<User> userList = query.getResultList(); // 处理查询结果 for (User user : userList) { System.out.println(user.getName()); } session.close(); ``` 在这个示例,我们创建了一个 CriteriaQuery 对象,并指定了要查询的实体类为 User。然后,我们通过 CriteriaBuilder 对象创建了一个 Predicate 对象,用于指定查询条件(这里是 age 字段等于 18)。最后,我们执行查询并处理查询结果。 需要注意的是,Criteria 查询是类型安全的,编译器会检查查询条件的正确性。此外,Criteria 查询还支持动态添加查询条件、多表关联查询等复杂的查询操作。希望以上信息能对你有所帮助!如果还有其他问题,请随时提问。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值