首页 > 其他 > 详细

【HQL】分页查询 、对象导航查询、外置命名查询、连接查询、查询过滤器、统计查询

时间:2016-10-28 02:20:09      阅读:228      评论:0      收藏:0      [点我收藏+]

分页查询

List students = session.createQuery("from Student")
                        .setFirstResult(1)
                        .setMaxResults(2)
                        .list();
            for (Iterator iter=students.iterator(); iter.hasNext();) {
                Student student = (Student)iter.next();
                System.out.println(student.getName());
            }

 

对象导航查询

session = HibernateUtils.getSession();
            session.beginTransaction();
            List students = session.createQuery("from Student s where s.classes.name like ‘%2%‘")
                        .list();
            for (Iterator iter=students.iterator(); iter.hasNext();) {
                Student student = (Student)iter.next();
                System.out.println(student.getName());
            }

 

外置命名查询

List students = session.getNamedQuery("queryStudent")
                                    .setParameter(0, 10)
                                    .list();
            for (Iterator iter=students.iterator(); iter.hasNext();) {
                Student student = (Student)iter.next();
                System.out.println(student.getName());
            }

 

连接查询

List students = session.createQuery("select c.name, s.name from Student s join s.classes c")
                        .list();
            for (Iterator iter=students.iterator(); iter.hasNext();) {
                Object[] obj = (Object[])iter.next();
                System.out.println(obj[0] + ", " + obj[1]);
            }
List students = session.createQuery("select c.name, s.name from Student s left join s.classes c")
                        .list();
            for (Iterator iter=students.iterator(); iter.hasNext();) {
                Object[] obj = (Object[])iter.next();
                System.out.println(obj[0] + ", " + obj[1]);
            }
List students = session.createQuery("select c.name, s.name from Student s right join s.classes c")
                        .list();
            for (Iterator iter=students.iterator(); iter.hasNext();) {
                Object[] obj = (Object[])iter.next();
                System.out.println(obj[0] + ", " + obj[1]);
            }

 

查询过滤器

session.enableFilter("testFilter")
                    .setParameter("myid", 10);
            List students = session.createQuery("from Student").list();
            for (Iterator iter=students.iterator(); iter.hasNext();) {
                Student student = (Student)iter.next();
                System.out.println(student.getName());
            }

 

统计查询

List list = session.createQuery("select count(*) from Student").list();
//            Long count = (Long)list.get(0);
            
            Long count = (Long)session.createQuery("select count(*) from Student").uniqueResult();
//            Long count = (Long)session.createQuery("select count(*) from Student")
//                    .setMaxResults(1)
//                    .uniqueResult();
            System.out.println("count=" + count);
String hql = "select c.name, count(s) from Classes c join c.students s group by c.name order by c.name";
            List students = session.createQuery(hql).list();
            for (int i=0; i<students.size(); i++) {
                Object[] obj = (Object[])students.get(i);
                System.out.println(obj[0] + ", " + obj[1]);
            }

 

【HQL】分页查询 、对象导航查询、外置命名查询、连接查询、查询过滤器、统计查询

原文:http://www.cnblogs.com/yinweitao/p/6006108.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!