使用Hibernate实现简单的增、改、删、查操作

作为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");


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

智学无忧-老曹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值