系列文章目录
文章目录
前言
一、session的api——save、get和load
save
save我们已经用了很多次了比如下图的把对象存到数据库里面去
get和load
get就是获取数据的
这句代码就相当于 select * from User where id=5
而在hibernate中就是这么简单,直接就获取到一个User对象了
注意我们的模型User要加一个ToString方法,这样才能打印看到效果
区别很简单:load获取不到数据会报错,而get获取不到会返回空
我们一般肯定用get
二、session的api——delete和update
delete
是什么原因呢?跟事务有关!
一定要注意,事务要打开
我们就直接在配置文件里面把自动提交事务打开算了
但是我们可以惊讶的发现配置文件里面的自动提交事务只对insert有效,对delete无效,因为我们的delete始终没有输出
那我们应该怎么做呢?
直接在test里面开启事务
这样就可以了,先查询,再delete
实际上我们没有必要去查询,因为效率不高,我们继续研究第二种方式:
创建一个User对象,设置一个id,然后直接删除(调用delete方法)
要注意,删除只认id
update
这样居然就成功修改了!让我们很纳闷,连关键词update都没有看到
update和save在有些时候是能够通用,都能够更新数据
按道理来说我们要加上一段update,但是实际上加和不加效果是一样的
所以我们要想能不能有更有效率的办法,即 只更新一个字段
实际上我们更新除了调用update还可以直接调用saveOrUpdate方法(千万不要搞混淆,以为是save方法)
它会自动判断,如果有这个id则更新,没有则添加
看看他们的区别
三、session的api——get和load方法的区别【面试题】
前面我们已经知道了, get/load都是通过id获取数据,get方法获取一个没有id的数据时,返回null, load方法获取一个没有id的数据时,报错
总结
1、get方法是直接加载数据库,load的设计是懒加载,用到时才去查询数据库,load方法返回的是对象的一个代理
2、 get/load都是通过id获取数据,get方法获取一个没有id的数据时,返回null, load方法获取一个没有id的数据时,报错
3、增删改才需要事务,查询是不需要事务的,即load和get不一定要写事务
4、配置文件里面的自动提交事务,只对insert语句(即save方法)有效,update和delete的还是要手动开启事务