zoukankan      html  css  js  c++  java
  • hibernate学习---用Session实现CURD

    我们使用Hibernate的目的是什么?对数据库进行操作,所有接下来我们就用Hibernate来进行CURD。

    前边我们已经分析过了Configuration,SessionFactory和Session,接下来我们就利用Session对象来进行增删改查:

    在进行增删改查之前我们先对SessionFactory和Session进行一些简单的封装:

    public class hbnUtil {
        private static SessionFactory factory;
    
        public static Session getSession() {
            return getSessionFactory().getCurrentSession();
        }
    
        public static SessionFactory getSessionFactory() {
            Configuration cfg = new Configuration().configure();//因为SessionFactory是重量级的,所以创建的时候要进行判断
            if(factory==null||factory.isClosed()) {
                factory = cfg.buildSessionFactory();
            }
    
            return factory;
        }
    }

    这样以后我们使用到Session实例对象的时候就能够进行直接获取了。

    增加操作:

    之前配置Hibernate的测试代码便是save操作,即增加一条记录。 
    还有一个方法也能够增加,叫做persist。 

      下面这段出自:http://blog.csdn.net/u010739551/article/details/47253881 

      Hibernate 之所以提供与save()功能几乎完全类似的persist()方法,一方面是为了照顾JPA的用法习惯。另一方面,save()和 persist()方法还有一个区别:使用 save() 方法保存持久化对象时,该方法返回该持久化对象的标识属性值(即对应记录的主键值);但使用 persist() 方法来保存持久化对象时,该方法没有任何返回值。因为 save() 方法需要立即返回持久化对象的标识属性,所以程序执行 save() 会立即将持久化对象对应的数据插入数据库;而 persist() 则保证当它在一个事物外部被调用时,并不立即转换成 insert 语句, 这个功能是很有用的,尤其当我们封装一个长会话流程的时候,persist() 方法就显得尤为重要了。

      主要内容区别:
    1,persist把一个瞬态的实例持久化,但是并”不保证”标识符(identifier主键对应的属性)被立刻填入到持久化实例中,标识符的填入可能被推迟到flush的时候。
    2,save, 把一个瞬态的实例持久化标识符,及时的产生,它要返回标识符,所以它会立即执行Sql insert 

    删除操作:

    public class TestDelete {
        public static void main(String[] args) {
            Session session  = hbnUtil.getSession();
            session.beginTransaction();
            Student student = new Student();
            student.setId(1);
            session.delete(student);
            session.getTransaction().commit();  
        }
    }

    因为我们指定的主键是id,所以进行删除的时候对主键为1的记录进行删除。

    更新操作:

    public class TestUpdate {
        public static void main(String[] args) {
            Session session  = hbnUtil.getSession();
            session.beginTransaction();
            Student student = new Student("李四",22,65);
            student.setId(2);
            session.update(student);
            session.getTransaction().commit();
        }
    }

    操作:

         Session session  = hbnUtil.getSession();
            session.beginTransaction();
            Student student = session.get(Student.class,2);
            System.out.println(student.toString());
            session.getTransaction().commit();

    查询还有一个方法叫做load方法(延迟加载),get方法当检索不到时候返回null而load方法会抛出错误。这里我们只需要知道load这个方法存在并且查询不到时会抛出错误就好了,具体的细节我们后面慢慢讨论。

    saveOrUpdate: 
    这个操作当存在id时执行update,当不存在id时执行save。

    注意:当增改删在同一个事务的时候,hibernate默认执行顺序是增改删但是可以通过刷新Session缓存来进行分割,对想要先执行的操作进行优先处理。
    比如你想先执行删除操作:
    session.delete(student);
    session.flush();
    session.save(“xxx”);
    像上面的这种方法就实现了删除优先。 

    到这里我们的基本增删改查就结束了。

    版权声明:本文为博主原创文章,如需转载请表明出处。 https://blog.csdn.net/qq_39266910/article/details/78565163

  • 相关阅读:
    触发Full GC执行的情况 以及其它补充信息
    HotSpot垃圾收集器GC的种类
    JVM学习之GC常用算法
    十大经典排序算法
    Java transient关键字使用
    Java并发编程:volatile关键字解析
    Linux Centos7.2 编译安装PHP7.0.2
    深入理解分布式事务及高并发下分布式事务的解决方案
    Windows及Linux环境搭建Redis集群
    软件项目进度管理(含敏捷项目管理)
  • 原文地址:https://www.cnblogs.com/chengshun/p/9771446.html
Copyright © 2011-2022 走看看