使用Hibernate达成简单的增、改、删、查操作
发布时间:2021-11-20 17:57:06 所属栏目:教程 来源:互联网
导读:作为Hibernate的初学者,要真正的掌握Hibernate,从简单的增、改、删、查开始。 1.增加(save或persist) 这两个方法都能实现数据的添加,主要区别在于:在没有开启事物时,save( )会执行相关的sql语句,然后在回滚,而persist根本不会执行sql语句。所以这两个
作为Hibernate的初学者,要真正的掌握Hibernate,从简单的增、改、删、查开始。 1.增加(save或persist) 这两个方法都能实现数据的添加,主要区别在于:在没有开启事物时,save( )会执行相关的sql语句,然后在回滚,而persist根本不会执行sql语句。所以这两个方法都要在事物中才能生效。 示例代码: Configuration conf = new Configuration(); conf.configure(); SessionFactory fac = conf.buildSessionFactory(); Session s = fac.openSession(); Transaction trans = s.beginTransaction(); Student stu = new Student(); stu.setAge(20); stu.setName("周杰伦"); s.save(stu);//添加数据 trans.commit(); s.close(); System.out.println("OK"); 2. 查询 (get或load) get和load都从数据库加载一条数据,不同在于:get会立即查询数据库,而load是一个懒加载,先返回代理对象,在使用的时候才真正的加载数据。 示例代码: Configuration conf = new Configuration(); conf.configure(); SessionFactory fac = conf.buildSessionFactory(); Session s = fac.openSession(); Transaction trans = s.beginTransaction(); Object obj = s.load(Student.class, 1);// 加载Id=1的记录 Student st = (Student) obj;// 强制转型 System.out.println("Name:" + st.getName()); trans.commit(); s.close(); System.out.println("OK"); 3. 修改 (update) 要先通过get或load得到要修改的对象,通过set修改对象的信息后,通过update方法更新到数据库。 示例代码: Configuration conf = new Configuration(); conf.configure(); SessionFactory fac = conf.buildSessionFactory(); Session s = fac.openSession(); Transaction trans = s.beginTransaction(); Object obj = s.load(Student.class, 1);// 加载Id=1的数据 Student st = (Student) obj;// 强制转型 st.setName("曹領雄");//修改名称 s.update(st);//更新数据 trans.commit();//提交事物 s.close(); System.out.println("OK"); 4. 删除 (delete) 要先通过get或load得到要删除的对象,然后通过delete方法删除该条记录。 示例代码: Configuration conf = new Configuration(); conf.configure(); SessionFactory fac = conf.buildSessionFactory(); Session s = fac.openSession(); Transaction trans = s.beginTransaction(); Object obj = s.load(Student.class, 1);// 加载Id=1的数据 Student st = (Student) obj;// 强制转型 s.delete(st);//删除该对象 trans.commit();// 提交事物 s.close(); System.out.println("OK"); ![]() (编辑:江门站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |