Hibernate的学习之路三十三(QBC的基本查询方式)
来源:互联网 发布:微软软件开发工具 编辑:程序博客网 时间:2024/06/06 01:09
前言
今天继续学习,之前贴出的大致图,再来一次。
技术分析之Hibernate框架的查询方式
1. 唯一标识OID的检索方式 * session.get(对象.class,OID)2. 对象的导航的方式3. HQL的检索方式 * Hibernate Query Language -- Hibernate的查询语言4. QBC的检索方式 * Query By Criteria -- 条件查询5. SQL检索方式(了解) * 本地的SQL检索
现在讲第4个。分析
技术分析之QBC检索方式
0. QBC:Query By Criteria 按条件进行查询1. 简单查询,使用的是Criteria接口 List<Customer> list = session.createCriteria(Customer.class).list(); for (Customer customer : list) { System.out.println(customer); }2. 排序查询 * 需要使用addOrder()的方法来设置参数,参数使用org.hibernate.criterion.Order对象 * 具体代码如下: Session session = HibernateUtils.getCurrentSession(); Transaction tr = session.beginTransaction(); Criteria criteria = session.createCriteria(Linkman.class); // 设置排序 criteria.addOrder(Order.desc("lkm_id")); List<Linkman> list = criteria.list(); for (Linkman linkman : list) { System.out.println(linkman); } tr.commit();3. 分页查询 * QBC的分页查询也是使用两个方法 * setFirstResult(); * setMaxResults(); * 代码如下; Session session = HibernateUtils.getCurrentSession(); Transaction tr = session.beginTransaction(); Criteria criteria = session.createCriteria(Linkman.class); // 设置排序 criteria.addOrder(Order.desc("lkm_id")); criteria.setFirstResult(0); criteria.setMaxResults(3); List<Linkman> list = criteria.list(); for (Linkman linkman : list) { System.out.println(linkman); } tr.commit();4. 条件查询(Criterion是查询条件的接口,Restrictions类是Hibernate框架提供的工具类,使用该工具类来设置查询条件) * 条件查询使用Criteria接口的add方法,用来传入条件。 * 使用Restrictions的添加条件的方法,来添加条件,例如: * Restrictions.eq -- 相等 * Restrictions.gt -- 大于号 * Restrictions.ge -- 大于等于 * Restrictions.lt -- 小于 * Restrictions.le -- 小于等于 * Restrictions.between -- 在之间 * Restrictions.like -- 模糊查询 * Restrictions.in -- 范围 * Restrictions.and -- 并且 * Restrictions.or -- 或者 * 测试代码如下 Session session = HibernateUtils.getCurrentSession(); Transaction tr = session.beginTransaction(); Criteria criteria = session.createCriteria(Linkman.class); // 设置排序 criteria.addOrder(Order.desc("lkm_id")); // 设置查询条件 criteria.add(Restrictions.or(Restrictions.eq("lkm_gender", "男"), Restrictions.gt("lkm_id", 3L))); List<Linkman> list = criteria.list(); for (Linkman linkman : list) { System.out.println(linkman); } tr.commit();5. 聚合函数查询(Projection的聚合函数的接口,而Projections是Hibernate提供的工具类,使用该工具类设置聚合函数查询) * 使用QBC的聚合函数查询,需要使用criteria.setProjection()方法 * 具体的代码如下 Session session = HibernateUtils.getCurrentSession(); Transaction tr = session.beginTransaction(); Criteria criteria = session.createCriteria(Linkman.class); criteria.setProjection(Projections.rowCount()); List<Number> list = criteria.list(); Long count = list.get(0).longValue(); System.out.println(count); tr.commit();
/** * 判断值是否为空 */@Testpublic void run7(){Session session = HibernateUtils.getCurrentSession();Transaction tr = session.beginTransaction();// 创建QBC查询接口Criteria criteria = session.createCriteria(Linkman.class);// 找所有的lkm_email是空的值criteria.add(Restrictions.isNull("lkm_email"));List<Linkman> list = criteria.list();for (Linkman linkman : list) {System.out.println(linkman);}tr.commit();}/** * 演示QBC的or方法 */@Testpublic void run6(){Session session = HibernateUtils.getCurrentSession();Transaction tr = session.beginTransaction();// 创建QBC查询接口Criteria criteria = session.createCriteria(Linkman.class);// SQL:select * from cst_linkman where lkm_gender = '女' or lkm_id > 3L;criteria.add(Restrictions.or(Restrictions.eq("lkm_gender", "女"), Restrictions.gt("lkm_id", 3L)));List<Linkman> list = criteria.list();for (Linkman linkman : list) {System.out.println(linkman);}tr.commit();}/** * in查询 */@Testpublic void run5(){Session session = HibernateUtils.getCurrentSession();Transaction tr = session.beginTransaction();// 创建QBC查询接口Criteria criteria = session.createCriteria(Linkman.class);// SQL:select * from cst_linkman where lkm_id in (1,2,7);List<Long> params = new ArrayList<Long>();params.add(1L);params.add(2L);params.add(7L);// 使用in 方法查询criteria.add(Restrictions.in("lkm_id", params));List<Linkman> list = criteria.list();for (Linkman linkman : list) {System.out.println(linkman);}tr.commit();}/** * QBC的条件查询 */@Testpublic void run4(){Session session = HibernateUtils.getCurrentSession();Transaction tr = session.beginTransaction();// 创建QBC查询接口Criteria criteria = session.createCriteria(Linkman.class);// 使用方法添加条件 and// criteria.add(Restrictions.eq("lkm_gender", "男"));// criteria.add(Restrictions.ge("lkm_id", 3L));// criteria.add(Restrictions.between("lkm_id", 2L, 5L));List<Linkman> list = criteria.list();for (Linkman linkman : list) {System.out.println(linkman);}tr.commit();}/** * QBC分页的方法和HQL分页的方式一样的 */@Testpublic void run3(){Session session = HibernateUtils.getCurrentSession();Transaction tr = session.beginTransaction();// 创建QBC查询接口Criteria criteria = session.createCriteria(Linkman.class);// 调用排序的方法,addOrder()criteria.addOrder(Order.desc("lkm_id"));// 设置分页的方法criteria.setFirstResult(0);criteria.setMaxResults(3);List<Linkman> list = criteria.list();for (Linkman linkman : list) {System.out.println(linkman);}tr.commit();}/** * QBC的基本入门查询 * 排序查询,调用的方法 */@Testpublic void run2(){Session session = HibernateUtils.getCurrentSession();Transaction tr = session.beginTransaction();// 创建QBC查询接口Criteria criteria = session.createCriteria(Linkman.class);// 调用排序的方法,addOrder()criteria.addOrder(Order.desc("lkm_id"));List<Linkman> list = criteria.list();for (Linkman linkman : list) {System.out.println(linkman);}tr.commit();}/** * QBC的基本入门查询 */@Testpublic void run1(){Session session = HibernateUtils.getCurrentSession();Transaction tr = session.beginTransaction();// 创建QBC查询接口Criteria criteria = session.createCriteria(Customer.class);List<Customer> list = criteria.list();for (Customer customer : list) {System.out.println(customer);}tr.commit();}
阅读全文
0 0
- Hibernate的学习之路三十三(QBC的基本查询方式)
- Hibernate的学习之路三十四(QBC的聚合函数的查询)
- Hibernate之QBC检索(查询)方式
- Hibernate QBC的查询方式的总结
- Hibernate QBC的查询方式的总结
- Hibernate QBC的查询方式的总结
- Hibernate的检索方式(4)QBC查询
- hibernate框架的查询方式QBC(二十)
- Hibernate的QBC查询
- Hibernate的QBC查询
- hibernate的QBC查询学习记录
- [Hibernate]Hibernate的QBC查询
- Hibernate QBC的学习
- hibernate QBC查询方式
- Hibernate的QBC检索方式
- Hibernate之QBC查询
- Hibernate 检索查询的几种方式(HQL,QBC,本地SQL,集成Spring等)
- Hibernate 检索查询的几种方式(HQL,QBC,本地SQL,集成Spring等)
- SpringBoot实现限制ip访问次数
- 在win7(32bit)下编译openssl
- Solr之精确、匹配、排序、模糊查询-yellowcong
- ORB-Slam2详解5 局部建图
- jmeter正则表达式提取多个值
- Hibernate的学习之路三十三(QBC的基本查询方式)
- OWASP Top10 2017发布,应用安全风险新增三名成员
- java 安装教程
- 接口和抽象类可以被new嘛?——顺便总结内部类
- 结构化数据库中主键与外键的作用
- java高分局之jstat命令使用
- spring+struts+mybatis三大框架整合配置
- v$sess_io视图
- centos清理磁盘被用完的情况