hibernate的saveOrUpdate方法

saveOrUpdate()方法到底怎么执行的?(原来和主键生成方式还有关系)

答:

该方法在执行过程中,需要一个对象作为参数。


如果主键生成方式为 手动设置:assigned:先执行select,有就update,没有就save

1)如果该对象存在 标识属性 ,(通俗点就是对应数据库中主键列的属性,如student的id属性,class的id属性,各种类的id属性):

 执行select * from table_name where id = ?  

若可以查到数据,则执行update操作,update tablename set proterty1 = param1 and proterty2 = param2 where id = ?;

如果查不到数据,则执行save操作。


2)如果该对象不存在标识属性:

hibernate报错,意思是没有指示主键是多少,hibernate不知道怎么往数据库插入。

【分析】:为什么会先执行一个select操作?因为assigned策略是委派策略,即主键是由自己定义的,如果不进行查询,程序就不知道数据库里是否已存在相同主键的数据(id相同是不能插入数据的),所以必须要先查询,已存在,则update;不存在,则save。



如果主键生成方式为 自动生成:identity or uuid ,没有select操作

1)如果该对象存在 标识属性 ,(通俗点就是对应数据库中主键列的属性,如student的id属性,class的id属性,各种类的id属性):

 执行update操作 update tablename set proterty1 = param1 and proterty2 = param2 where id = ?:

若数据库表中有匹配该id的数据,修改成功。

若数据库表中没有匹配该id的数据,hibernate报错。


2)如果该对象不存在标识属性:

hibernate直接执行save 操作,自动生成主键,成功插入该数据进入数据库。

【分析】:为什么此处就不需要先执行select语句呢?因为主键策略是自动生成的,程序不会生成两个相同的主键,因此不存在数据库里有相同主键这种可能性。所以,如果对象带标识就直接update,对象不带标识就直接save。


第一篇文章,根据网上的内容进行整理和修改的,加了自己的一些理解,如果有不正确或不准确的地方,请留言告知我,我及时改正。

你可能感兴趣的:(hibernate的saveOrUpdate方法)