hibernate查询
2016-06-23 22:23
375 查看
hibernate查询
HQL查询( Hibernate Query language hibernate 提供的面向对象的查询语言。)
public class App { private static SessionFactory sf; static { sf = new Configuration() .configure() .addClass(Dept.class) .addClass(Employee.class) // 测试时候使用 .buildSessionFactory(); } /* * 1) Get/load主键查询 2) 对象导航查询 3) HQL查询, Hibernate Query language hibernate 提供的面向对象的查询语言。 4) Criteria 查询, 完全面向对象的查询(Query By Criteria ,QBC) 5) SQLQuery, 本地SQL查询 */ @Test public void all() { Session session = sf.openSession(); session.beginTransaction(); //1) 主键查询 // Dept dept = (Dept) session.get(Dept.class, 12); // Dept dept = (Dept) session.load(Dept.class, 12); //2) 对象导航查询 // Dept dept = (Dept) session.get(Dept.class, 12); // System.out.println(dept.getDeptName()); // System.out.println(dept.getEmps()); // 3) HQL查询 // 注意:使用hql查询的时候 auto-import="true" 要设置true, // 如果是false,写hql的时候,要指定类的全名 // Query q = session.createQuery("from Dept"); // System.out.println(q.list()); // a. 查询全部列 // Query q = session.createQuery("from Dept"); //OK // Query q = session.createQuery("select * from Dept"); //NOK, 错误,不支持* // Query q = session.createQuery("select d from Dept d"); // OK // System.out.println(q.list()); // b. 查询指定的列 【返回对象数据Object[] 】 // Query q = session.createQuery("select d.deptId,d.deptName from Dept d"); // System.out.println(q.list()); // c. 查询指定的列, 自动封装为对象 【必须要提供带参数构造器】 // Query q = session.createQuery("select new Dept(d.deptId,d.deptName) from Dept d"); // System.out.println(q.list()); // d. 条件查询: 一个条件/多个条件and or/between and/模糊查询 // 条件查询: 占位符 // Query q = session.createQuery("from Dept d where deptName=?"); // q.setString(0, "财务部"); // q.setParameter(0, "财务部"); // System.out.println(q.list()); // 条件查询: 命名参数 // Query q = session.createQuery("from Dept d where deptId=:myId or deptName=:name"); // q.setParameter("myId", 12); // q.setParameter("name", "财务部"); // System.out.println(q.list()); // 范围 // Query q = session.createQuery("from Dept d where deptId between ? and ?"); // q.setParameter(0, 1); // q.setParameter(1, 20); // System.out.println(q.list()); // 模糊 // Query q = session.createQuery("from Dept d where deptName like ?"); // q.setString(0, "%部%"); // System.out.println(q.list()); // e. 聚合函数统计 // Query q = session.createQuery("select count(*) from Dept"); // Long num = (Long) q.uniqueResult(); // System.out.println(num); // f. 分组查询 //-- 统计t_employee表中,每个部门的人数 //数据库写法:SELECT dept_id,COUNT(*) FROM t_employee GROUP BY dept_id; // HQL写法 // Query q = session.createQuery("select e.dept, count(*) from Employee e group by e.dept"); // System.out.println(q.list()); session.getTransaction().commit(); session.close(); } // g. 连接查询 @Test public void join() { Session session = sf.openSession(); session.beginTransaction(); //1) 内连接 【映射已经配置好了关系,关联的时候,直接写对象的属性即可】 // Query q = session.createQuery("from Dept d inner join d.emps"); //2) 左外连接 // Query q = session.createQuery("from Dept d left join d.emps"); //3) 右外连接 Query q = session.createQuery("from Employee e right join e.dept"); q.list(); session.getTransaction().commit(); session.close(); } // g. 连接查询 - 迫切连接 @Test public void fetch() { Session session = sf.openSession(); session.beginTransaction(); //1) 迫切内连接 【使用fetch, 会把右表的数据,填充到左表对象中!】 // Query q = session.createQuery("from Dept d inner join fetch d.emps"); // q.list(); //2) 迫切左外连接 Query q = session.createQuery("from Dept d left join fetch d.emps"); q.list(); session.getTransaction().commit(); session.close(); } // HQL查询优化 @Test public void hql_other() { Session session = sf.openSession(); session.beginTransaction(); // HQL写死 // Query q = session.createQuery("from Dept d where deptId < 10 "); // HQL 放到映射文件中 Query q = session.getNamedQuery("getAllDept"); q.setParameter(0, 10); System.out.println(q.list()); session.getTransaction().commit(); session.close(); } }
Criteria 查询(完全面向对象的查询(Query By Criteria ,QBC))
//4) Criteria 查询, @Test public void criteria() { Session session = sf.openSession(); session.beginTransaction(); Criteria criteria = session.createCriteria(Employee.class); // 构建条件 criteria.add(Restrictions.eq("empId", 12)); // criteria.add(Restrictions.idEq(12)); // 主键查询 System.out.println(criteria.list()); session.getTransaction().commit(); session.close(); }
SQLQuery, 本地SQL查询
// 5) SQLQuery, 本地SQL查询 // 不能跨数据库平台: 如果该了数据库,sql语句有肯能要改。 @Test public void sql() { Session session = sf.openSession(); session.beginTransaction(); SQLQuery q = session.createSQLQuery("SELECT * FROM t_Dept limit 5;") .addEntity(Dept.class); // 也可以自动封装 System.out.println(q.list()); session.getTransaction().commit(); session.close(); }
分页查询
分页SQL: 先查询总记录数,再分页查询。// 分页查询 @Test public void all() { Session session = sf.openSession(); session.beginTransaction(); Query q = session.createQuery("from Employee"); // 从记录数 ScrollableResults scroll = q.scroll(); // 得到滚动的结果集 scroll.last(); // 滚动到最后一行 int totalCount = scroll.getRowNumber() + 1;// 得到滚到的记录数,即总记录数 // 设置分页参数 q.setFirstResult(0); q.setMaxResults(3); // 查询 System.out.println(q.list()); System.out.println("总记录数:" + totalCount); session.getTransaction().commit(); session.close(); }
相关文章推荐
- 15.2
- (原) 2.1 Zookeeper原生API使用
- linux重点总结
- C++类实践——时间类
- requestWindowFeature()隐藏标题栏无效
- 问题 G: 车站调度
- 编写优雅的JavaScript——前言
- jsp 连接mysql插入数据乱码
- 两个链表的第一个公共结点
- Xml解析网络数据
- OpenCV(2)-Mat数据结构及访问Mat中像素
- String的split()方法的两种使用方式
- Android 自定义倒计时的View demo 类似CountDownTimer
- [方案]解决魅族USB调试无法被电脑识别的问题(含Mac OS X、Win7)
- C#高级功能(一)Lambda 表达式
- Android常用的设计模式(一)
- UILabel 内容长度太长宽度有限可以使用下面这个属性
- SQL Server 的备份与恢复
- linux内核之页高速缓存
- 第四百四十六、七天 how can I 坚持