Hibernate(八)
三套查询之Criteria查询
完全面向对象的,不需要写任可查询语句.
1.查询所有的学生
//1.查询所有的学生
@Test
public void test1(){
Criteria criteria = session.createCriteria(Student.class);
List<Student> list = criteria.list();
for (Student student : list) {
System.out.println(student.getId()+student.getName());
} Criteria criteria2 = session.createCriteria("com.rong.entity.group.Student");
List<Student> list2 = criteria2.list();
for (Student student : list2) {
System.out.println(student.getId()+student.getName());
}
}
2.添加查询条件
add(Criterion criterion) : 添加查询条件.
Criterion : 代表一个查询条件.
Restrictions工具类,专门负责生成查询条件对象,它把where部分都改成了静态方法。
sqlRestriction(String sql) : 生成查询条件的万能方法.
Property工具类,专门负责生成查询条件对象.
Propery.forName("属性名").xxx()
//2.添加查询条件
@Test
public void test2(){
//1.添加一个
Criteria criteria = session.createCriteria(Student.class);
criteria=criteria.add(Restrictions.like("name", "%ab%"));
List<Student> list = criteria.list();
for (Student student : list) {
System.out.println(student.getId()+student.getName());
}
//2.添加多个
Criteria criteria2 = session.createCriteria(Student.class);
criteria2.add(Restrictions.like("name", "%a%"));
criteria2.add(Restrictions.between("java", 60, 100));
List<Student> list2 = criteria2.list();
for (Student student : list2) {
System.out.println(student.getId()+student.getName());
}
System.out.println("===================================");
Criteria criteria3 = session.createCriteria(Student.class);
criteria3.add(Property.forName("name").like("%p%"));
criteria3.add(Property.forName("math").between(85, 100));
List<Student> list3 = criteria3.list();
for (Student student : list3) {
System.out.println(student.getId()+student.getName()
+student.getMath());
}
}
3.添加自己的sql
//3.添加自己的sql
@Test
public void test3(){
Criteria criteria = session.createCriteria(Student.class);
criteria.add(Restrictions.sqlRestriction("length(name)>4 and name like '%a%'"));
List<Student> list = criteria.list();
for (Student student : list) {
System.out.println(student.getId()+student.getName());
}
}
4.排序
addOrder(Order order) : 添加排序.
Order.asc("属性名") | Order.desc("属性名")
Property.forName("age").asc()|Property.forName("age").desc()
//4.排序
@Test
public void test4(){
//第一种方式
Criteria criteria = session.createCriteria(Student.class);
criteria.add(Restrictions.lt("id", 10));
criteria.addOrder(Order.asc("java"));//升序
List<Student> list = criteria.list();
for (Student student : list) {
System.out.println(student.getId()+student.getName()+student.getJava());
}
Criteria criteria2 = session.createCriteria(Student.class);
criteria2.add(Restrictions.gt("id", 90));
criteria2.addOrder(Order.desc("math"));//降序
List<Student> list2 = criteria2.list();
for (Student student : list2) {
System.out.println(student.getId()+student.getName()+student.getMath());
}
//第二种方式
Criteria criteria3 = session.createCriteria(Student.class);
List<Student> list3 = criteria3.addOrder(Property.forName("java").asc()).list();
for (Student student : list3) {
System.out.println(student.getId()+student.getName()+student.getJava());
}
Criteria criteria4 = session.createCriteria(Student.class);
List<Student> list4 = criteria4.addOrder(Property.forName("java").desc()).list();
for (Student student : list4) {
System.out.println(student.getId()+student.getName()+student.getJava());
}
}
5.查询一列
setProjection(Projection projection): 查询哪些列.
Projection : 代表一列
ProjectionList : 代表多列
Projections : 专门创建Projection | ProjectionList
//5.查询一列
@Test
public void test5(){
Criteria criteria = session.createCriteria(Student.class);
criteria.setProjection(Projections.property("name"));
List<String> list = criteria.list();
for (String string : list) {
System.out.println(string);
}
}
6.查询多列
//6.查询多列
@Test
public void test6(){
Criteria criteria = session.createCriteria(Student.class);
ProjectionList pl = Projections.projectionList();
pl.add(Projections.property("java"));
pl.add(Projections.property("math"));
criteria.setProjection(pl);
//criteria.setProjection(Projections.projectionList().add(Projections.property("java"))
// .add(Projections.property("math")));
List<Object[]> list = criteria.list();
for (Object[] objects : list) {
for (Object object : objects) {
System.out.print(object+"\t");
}
System.out.println();
}
}
7.聚集函数
//7.聚集函数
@Test
public void test7(){
Criteria criteria = session.createCriteria(Student.class);
criteria.setProjection(Projections.rowCount());
criteria.add(Restrictions.between("id", 10, 20));
Object rowCount = criteria.uniqueResult();
System.out.println("id在10到20之间的数量为:"+rowCount);
Criteria criteria2 = session.createCriteria(Student.class);
criteria2.setProjection(Projections.sum("java"));
criteria2.add(Property.forName("id").between(1, 3));
Object sum = criteria2.uniqueResult();
System.out.println("id为1到3的java成绩总和为:"+sum);
}
8.分组
//8.分组
@Test
public void test8(){
Criteria criteria = session.createCriteria(Student.class);
criteria.setProjection(Projections.projectionList().add(Projections.rowCount()).add(Projections.groupProperty("teacher.id")));
List<Object[]> list = criteria.list();
for (Object[] objects : list) {
for (Object object : objects) {
System.out.println(object);
}
}
}
9.通过老师id查询学生(使用别名查询)
setFetchMode(String associationPath, FetchMode mode): 抓取连接(join fetch)
FetchMode: 抓取模式
FetchMode.JOIN FetchMode.EAGER 立即查询
FetchMode.SELECT FetchMode.LAZY 延迟查询
//9.通过老师id查询学生(使用别名查询)
@Test
public void test9(){
Criteria criteria = session.createCriteria(Student.class);
criteria.add(Restrictions.eq("teacher.tid", 1));
List<Student> list = criteria.list();
for (Student student : list) {
System.out.println(student.getName()+student.getTeacher().getTid());
}
System.out.println("=============以下是通过别名查询================");
Criteria criteria2 = session.createCriteria(Student.class);
criteria2.createAlias("teacher", "t");
criteria2.add(Restrictions.eq("t.id", 1));
List<Student> list2 = criteria2.list();
for (Student student : list2) {
System.out.println(student.getName()+student.getTeacher().getTid());
}
}
//setFetchMode: 抓取延迟的属性
Criteria criteria3 = session.createCriteria(Student.class);
criteria3.setFetchMode("teacher", FetchMode.JOIN);
List<Student> list3 = criteria3.list();
/*for (Student student : list3) {
System.out.println(student.getName()+student.getTeacher().getTid());
}*/
10.离线查询
离线查询 DetachedCriteria.
DetachedCriteria :用它就可以定义一条查询语句. select * from stu_info.
用得时候需要与Session关联起来.
离线查询的主要作用就是为了做子查询. in 、not in(离线查询对象)
//10.离线查询
@Test
public void test10(){
DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Student.class);
Criteria criteria = detachedCriteria.getExecutableCriteria(session);
List<Student> list = criteria.list();
for (Student student : list) {
System.out.println(student.getId()+student.getName());
}
}
11.子查询
//11.子查询
@Test
public void test11(){
Criteria criteria = session.createCriteria(Student.class);
criteria.add(Restrictions.in("id", new Object[]{1,2,3}));
List<Student> list = criteria.list();
for (Student student : list) {
System.out.println(student.getId()+student.getName());
}
System.out.println("==================================");
//离线查询作为子查询的一部分
DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Student.class);
detachedCriteria.setProjection(Projections.property("id"));
detachedCriteria.add(Restrictions.between("id", 60, 90));
Criteria criteria2 = session.createCriteria(Student.class);
criteria2.add(Property.forName("id").in(detachedCriteria));
List<Student> list2 = criteria2.list();
for (Student student : list2) {
System.out.println(student.getId()+student.getName());
}
}
Hibernate(八)的更多相关文章
- hibernate(八) Hibernate检索策略(类级别,关联级别,批量检索)详解
序言 很多看起来很难的东西其实并不难,关键是看自己是否花费了时间和精力去看,如果一个东西你能看得懂,同样的,别人也能看得懂,体现不出和别人的差距,所以当你觉得自己看了很多书或者学了很多东西的时候,你要 ...
- Hibernate(八)__级联操作、struts+hibernate+接口编程架构
级联操作 所谓级联操作就是说,当你进行主对象某个操作时,从对象hibernate自动完成相应操作. 比如: Department <---->Student 对象关系,我希望当我删除一个d ...
- Hibernate(八)多对多映射
一.创建数据表 --学生证表 create table paper ( pid number primary key, pdesc ) , sid number references student( ...
- Hibernate(八)--session的两种获取方式
openSession getCurrentSession Hibernate有两种方式获得session,分别是: openSession和getCurrentSession他们的区别在于1. 获取 ...
- 八步详解Hibernate的搭建及使用
本文通过了八个步骤以及一些实例添加用户来介绍Hibernate的搭建和使用,真切的介绍了hibernate的基本用法,其中好多优点等待我们自己去发现,比如hibernate中的缓存机制,映射方案. 1 ...
- (Hibernate进阶)Hibernate映射——多对多关联映射(八)
多对多映射是现实生活中最常见的映射,也是最容易理解的映射.废话少说,直接开始. 映射原理 不论是单向关联还是双向关联都是通过第三张表,将两个表中的主键放到第三张做一个关联.用第三张表来解决可能会造成数 ...
- [Java面试八]Hibernate总结以及在面试中的一些问题.
1.为什么要使用Hibernate开发你的项目呢?Hibernate的开发流程是怎么样的? 为什么要使用 ①.对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码. ②.Hiber ...
- hibernate(八)一对多关联
一.一对多单向关良 一对多单向关联与多对一相似 假设一个组有多个用户,即一(Group)对多(User) 需要在Group类中添加一个User类的Set集合(数据库中的用户不可能是重复的,所以要用Se ...
- HIbernate的基本包——八个,详细条目
antlr-2.7.6commons-collections-3.1dom4j-1.6.1hibernate3javassist-3.9.0.GAjta-1.1slf4j-api-1.5.8slf4j ...
- 攻城狮在路上(壹) Hibernate(十八)--- 管理Hibernate的缓存
一般Session的缓存被称为Hibernate的第一级缓存,SessionFactory的外置缓存是一个可配置的缓存插件,称为Hibernate的第二级缓存.一.缓存的基本原理: 1.持久化层的缓存 ...
随机推荐
- 字符编码——python学习
python学习—字符编码 例如汉字“中” 十进制:20013 二进制:01001110 00101101(unicode)/11100100 10111000 10101101(utf-8) 十六进 ...
- xshell sftp可用命令,sftp: cannot open d: to write![解决]
sftp可用命令: cd 路径 更改远程目录到“路径” lcd 路径 更改本地目录到“路径” chgrp group path 将文件“path”的组更改为“group” chmod mode pat ...
- 我遇到的有关git的问题及解决方法总结
有关git的问题 ** 1.在github上创建项目 2.使用git clone https://github.com/xxxxxxx/xxxxx.git克隆到本地 3.编辑项目 4.git add ...
- 20155310 2016-2017-2 《Java程序设计》第四周学习总结
20155310 2016-2017-2 <Java程序设计>第四周学习总结 一周两章新知识的自学与理解真的是很考验和锻炼我们,也对前面几章我们的学习进行了检测,遇到忘记和不懂的知识就再复 ...
- 20155336 《Java程序设计》实验一(Java开发环境的熟悉)实验报告
20155336 <Java程序设计>实验一(Java开发环境的熟悉)实验报告 实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用Eclipse 编辑.编译.运行.调试Jav ...
- 简单的Slony-I设置实例
磨砺技术珠矶,践行数据之道,追求卓越价值 回到上一级页面: PostgreSQL集群方案相关索引页 回到顶级页面:PostgreSQL索引页 参考如下链接: http://lets.postg ...
- [arc082E]ConvexScore-[凸包]
Description 传送门 Solution em又是神仙题. 考虑到目前的一个凸包,顶点点集为S. 现在在它内部或边缘上的点集为T,则贡献为2|T|−|S|,设从T中去掉S的点后得到了集合A.则 ...
- 【转载】D3D深度测试和Alpha混合
原文:D3D深度测试和Alpha混合 1. 深度测试 a) 深度缓冲区:屏幕上每个像素点的深度信息的一块内存缓冲区.D3D通过比较当前绘制的像素点的深度和对应深度缓冲区的点 ...
- day7 RHCE
6.配置本地邮件服务 在系统server0和desktop0上配置邮件服务,满足以下要求:这些系统不接收外部发送来的邮件这些系统上本地发送的任何邮件都会自动路由到 classroom.example. ...
- kali2.0下JAVA安装
参考网址:http://www.blackmoreops.com/2013/10/26/how-to-install-java-jdk-in-kali-linux/ 1.下载javase,http:/ ...