zoukankan      html  css  js  c++  java
  • hibernate二级缓存demo2

        @Test
        public void hello3(){
            
            Session session=sessionFactory.openSession();
            List list = session.createQuery("from User").list();
            System.out.println(list);
            session.close();
            
            /**
             * 由于学生的对象已经缓存在二级缓存中了,此时再使用iterate来获取对象的时候,首先会通过一条
             * 取id的语句,然后在获取对象时去二级缓存中,如果发现就不会再发SQL,这样也就解决了N+1问题 
             * 而且内存占用也不多
             */
            Session session2=sessionFactory.openSession();
            Iterator iterate = session2.createQuery("from User").iterate();
            while (iterate.hasNext()) {
                User user = (User) iterate.next();
                System.out.println(user);
                System.out.println(user.getId());
            }
            session2.close();        
        }
    Hibernate: 
        select
            user0_.id as id1_5_,
            user0_.name as name2_5_ 
        from
            tt_user user0_
    [User [id=1, name=aaa], User [id=2, name=bbb]]
    Hibernate: 
        select
            user0_.id as col_0_0_ 
        from
            tt_user user0_
    Hibernate: 
        select
            user0_.id as id1_5_0_,
            user0_.name as name2_5_0_ 
        from
            tt_user user0_ 
        where
            user0_.id=?
    User [id=1, name=aaa]
    1
    Hibernate: 
        select
            user0_.id as id1_5_0_,
            user0_.name as name2_5_0_ 
        from
            tt_user user0_ 
        where
            user0_.id=?
    User [id=2, name=bbb]
    2

    配置hibernate二级缓存之后:

    Hibernate: 
        select
            user0_.id as id1_5_,
            user0_.name as name2_5_ 
        from
            tt_user user0_
    [User [id=1, name=aaa], User [id=2, name=bbb]]
    Hibernate: 
        select
            user0_.id as col_0_0_ 
        from
            tt_user user0_
    User [id=1, name=aaa]
    1
    User [id=2, name=bbb]
    2
  • 相关阅读:
    用shell脚本监控进程是否存在 不存在则启动的实例
    vue+element-ui+ajax实现一个表格的实例
    c的指针和php中的引用的区别
    mysql or条件查询优化
    Linq查询操作之投影操作
    Linq查询操作之Where筛选
    Linq专题之查询操作
    linq之join子句
    linq之let子句
    linq之into子句
  • 原文地址:https://www.cnblogs.com/Danial7777777/p/9351735.html
Copyright © 2011-2022 走看看