美文网首页
Hibernate各类概念

Hibernate各类概念

作者: ticktackdong | 来源:发表于2018-05-08 13:20 被阅读0次

    一.事务

     Hibernate的任何对数据有改动的操作,都应该被放在事务里面. 
     hibernate中的事务由s.beginTransaction();开始
     //中间是多个操作啊,表类型必须是INNODB
     由s.getTransaction().commit();结束
    

    二.延迟加载lazyload

    属性延迟加载  当使用load的方式来获取对象的时候
                 只有访问了这个对象的属性 
                 hibernate才会到数据库中进行查询。
                 否则不会访问数据库
            Product p = (Product)s.load(Product.class, 1);
           //还没有访问数据库
            System.out.println(p.getName());
           //访问属性时才访问数据库
    关系延迟加载   在one-many many-many的时可用
                 修改Category.hbm.xml中的<set name="products" lazy="true">
                 表示通过Category获取产品是延迟加载的
             Category c = (Category) s.get(Category.class, 1);
         //只会查询Category表的信息不会查询product_表
        System.out.println(c.getProducts());
        //通过category取products时才会进行对product_表的查询
    

    三.级联

      四种级联
        all:所有操作都执行级联操作
        none:所有操作都不执行级联操作
        delete:删除时执行级联操作
        save-update:保存和更新时执行级联操作
       1.delete级联
         在Category.hbm.xml加上
        <set name="products" cascade="delete" lazy="false">
       2.save-update级联
          <set name="products" cascade="save-update" lazy="false">
    

    四.一级缓存

     默认开启,存放在Session上
    

    五.二级缓存

     hibernate.cfg.xml 中增加对二级缓存的配置,存放在SessionFactory上
    

    六.使用Criterria进行分页查询

      无论使用的是Oracle,Mysql,NoSQL还是DB2,分页查询的代码写法都是一样的
          Criteria c= s.createCriteria(Product.class);
        c.add(Restrictions.like("name", "%"+name+"%"));
        c.setFirstResult(2);//表示从第二条数据开始
        c.setMaxResults(5);//表示一共查询5条数据
    

    七.get/load获取方式

                   是否延迟加载               id不存在对象
     load 只有属性被访问时才会调用sql语句         抛出异常
     get   无论后面是否访问属性马上执行sql语句    返回null
    

    八.两种获得session方式

    openSession        每次得到一个新的session
                     只有增加删除修改需要事务,查询时不需要
    getCurrentSession 在同一个线程每次都是相同的Session
                   所有操作都放在事务中进行,提交事务后session自动关闭,不能再进行关闭
    

    九.N+1

       1,就是指只返回id的SQL语句
       N指的是如果在缓存中找不到对应的数据,就到数据库中去查
       Hibernate有缓存机制,可以通过用id作为key把product对象保存在缓存中 
        首先通过Query的iterator把所有满足条件的Product的id查出来
    
        然后再通过it.next()查询每一个对象
       如果这个对象在缓存中,就直接从缓存中取了
       否则就从数据库中获取
       同时hibernate也提供Query的查询方式。
       假设数据库中有100条记录,其中有30条记录在缓存中,
       但是使用Query的list方法,就会所有的100条数据都从数据库中查询,而无视这30条缓存中的记录 
    

    十.查询总数

        Query q =s.createQuery("select count(*) from Product p where p.name like ?");
        q.setString(0, "%"+name+"%");
        long total= (Long) q.uniqueResult();
    

    十一.乐观锁

    十二.C3P0连接池

    相关文章

      网友评论

          本文标题:Hibernate各类概念

          本文链接:https://www.haomeiwen.com/subject/ohwvrftx.html