Java Criteria使用方法
2024-08-29 01:41:32
Criteria Query 可以看作传统sql的对象化表示。
Criteria 可以由session创建。
Criteria ct= session.createCriteria(TUser.class);
先来一段小Demo:
TbItemParamExample example = new TbItemParamExample();
Criteria criteria = example.createCriteria();
criteria.andItemCatIdEqualTo(cid);
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();
最新文章
- Multiple actions were found that match the request Web API
- 小度Wifi_设置
- wordpress编辑器无法切换/输入
- 第一篇、HTML标签
- phpstudy虚拟主机配置
- Remove Invalid Parentheses 解答
- ThinkPHP第十三天(CONF_PATH、APP_PATH,UEditor用法)
- 函数指针&;amp;绑定: boost::functoin/std::function/bind
- iOS开发那些事-iOS6苹果地图有用开发
- 部署 instance 到 OVS vlan100 - 每天5分钟玩转 OpenStack(138)
- diff命令参数
- K:枚举的线程安全性及其序列化问题
- Docker部署Elasticsearch集群
- Python3 ——斐波那契数列(经典)
- [Swift]LeetCode900. RLE 迭代器 | RLE Iterator
- mac openresty 源码安装 坑
- Python——python读取html实战,作业7(python programming)
- SRILM的使用及平滑方法说明
- C#设计模式(9)——代理模式
- Hive表种map字段的查询取用
热门文章
- 03 | 变量的解构赋值 | es6
- 1.在项目中使用D3.js
- Solon &; Solon Cloud 1.5.62 发布,轻量级 Java 基础开发框架
- 『与善仁』Appium基础 — 8、Appium自动化测试框架介绍
- 让textarea根据文本的长度自动调整它的高度
- linux安装python3.6.1
- [bzoj4971]记忆中的背包
- [atARC061F]Card Game for Three
- [atAGC020E]Encoding Subsets
- 【Spring】(1)-- 概述