Hibernate中的createQuery查询一条数据、多条数据、分页查询数据

package com.ckinghan.test;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.classic.Session;
import org.junit.Test;

import com.ckinghan.bean.User;

public class HibernateQueryApi {

    /**
     * Hibernate 中的createQuery查询一条数据、多条数据、分页查询数据
     */
    @Test
    public void hibernateQuery1(){
        //加载Hibernate的配置文件信息
        Configuration configuration = new Configuration().configure();
        //通过配置文件信息创建SessionFactory
        SessionFactory buildSessionFactory = configuration.buildSessionFactory();
        //通过SessionFactory获取与当前线程绑定的Session
        Session currentSession = buildSessionFactory.getCurrentSession();
        //对Session启动事务 
        Transaction transaction = currentSession.beginTransaction();
        //创建HQL的查询语句
        Query createQuery = currentSession.createQuery("from User where id = 1");

        //获取一条数据,但要注意,如果查询返回的结果集是多条数据,会报错,如果未查询到数据,返回null
        User user  = (User) createQuery.uniqueResult();
        System.out.println("查询一条数据:");
        System.out.println(user);

        //获取多条数据,不管是调用uniqueResult()方法时还是调用list方法,都会重新执行一次SQL查询语句
        List<User> users = (List<User>) createQuery.list();
        System.out.println("查询多条数据:");
        System.out.println(users);

        //分页功能,设置分页的起始索引
        createQuery.setFirstResult(0);
        //设置分页每次获取的数据数量
        createQuery.setMaxResults(100);
        //查询数据
        createQuery = currentSession.createQuery("from User");
        List<User> list = createQuery.list();
        //输出查询到的结果集
        System.out.println("分页查询数据:");
        System.out.println(list);

        //提交事务
        transaction.commit();
        //关闭SessionFactory
        buildSessionFactory.close();
    }
}

执行结果 如下:

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Hibernate: 
    select
        user0_.id as id0_,
        user0_.userName as userName0_,
        user0_.password as password0_ 
    from
        user user0_ 
    where
        user0_.id=1
查询一条数据:
User [id=1, userName=userName, password=password123]
Hibernate: 
    select
        user0_.id as id0_,
        user0_.userName as userName0_,
        user0_.password as password0_ 
    from
        user user0_ 
    where
        user0_.id=1
查询多条数据:
[User [id=1, userName=userName, password=password123]]
Hibernate: 
    select
        user0_.id as id0_,
        user0_.userName as userName0_,
        user0_.password as password0_ 
    from
        user user0_
分页查询数据:
[User [id=1, userName=userName, password=password123], User [id=2, userName=userName, password=password123]]
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernatequery 博客分类: • Hibernate HibernateSQLSQL ServerMySQLJDBC Hibernatequery.setFirstResult(),query.setMaxResults(); 一、query.scroll()和query.setFirstResult(),query.setMaxResults();这两种方法都可以取到一定范围内的数据,用来数据分页显示。那么两者区别,以及两者的效率如何? 答:1.scroll是用JDBC2.0的可滚动结果集实现;query.setMaxResults();query.setFirstResult()是数据库SQL语句实现。 2.你说是在数据库就分页好呢?还是把结果集都取到内存再分页好呢?(应该是在数据库就分了好些吧,但是如果在内存分页的话,换页的时候是不是更快一些呢?) 3.在数据库进行分页是首选的方式。数据库分页实际上是利用数据库本身SQL扩展的功能进行分页,例如MySQL的 limit 0,50这样的SQL语句。不但速度快,而且非常节省内存。不过不是每种数据库的都有这种分页支持的SQL,例如SQL Server就不支持。 4.scroll是利用JDBC2.0的功能做分页的,那么就完全取决于特定数据库的JDBC Driver的实现了。事实上大部分JDBC Driver都是把所有的结果集都一次取到内存,然后再分页的。如果这个结果集非常大,例如几万条,不但程序执行速度会很慢,而且很容易导致out of memory。当然个别JDBC Driver使用了服务器端游标来实现,那么就不会导致这种问题,例如jTDS。 二、Hibernate可以使用Query.setMaxResults方法简地设置需要查询的最大结果集。 然后Hibernate会自动根据所设置的数据库方言翻译成相应的SQL语句提交给数据库。比如如果数据库是Oracle,SQL Server等,则翻译为类似select ... top 10之类的SQL语句,若是MySQL,则翻译为select ... limit 10之类的SQL。 三、举例: Java代码 1. import org.hibernate.Query; 2. 3. query.setFirstResult(0),query.setMaxResults(4);相当于MySQL的limit 0, 4; 4. public void testQuery() { 5. Session session = null; 6. try { 7. session = HibernateUtils.getSession(); 8. session.beginTransaction(); 9. Query query = session.createQuery("from User"); 10. query.setFirstResult(0);//从第一条记录开始 11. query.setMaxResults(4);//取出四条记录 12. List userList = query.list(); 13. for (Iterator iter=userList.iterator(); iter.hasNext();) { 14. User user = (User)iter.next(); 15. System.out.println(user.getId()); 16. System.out.println(user.getName()); 17. } 18. session.getTransaction().commit(); 19. }catch(Exception e) { 20. e.printStackTrace(); 21. session.getTransaction().rollback(); 22. }finally { 23. HibernateUtils.closeSession(session); 24. } 25. }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值