相关文章推荐
茫然的风衣  ·  Java SE 6 — 更好的 ...·  3 天前    · 
曾深爱过的沙滩裤  ·  使用Spring Data ...·  3 天前    · 
八块腹肌的小蝌蚪  ·  Springboot ...·  3 天前    · 
飘逸的小熊猫  ·  C++ ...·  1 年前    · 
直爽的柿子  ·  os.mkdir()与os.makedirs ...·  1 年前    · 
买醉的钥匙  ·  powershell & bash ...·  1 年前    · 

save是CrudRepository下的。

saveAndFlush是JpaRepository下的。

一般情况下save就足够了,但是如果在同一个transaction里,比如你在方法上标了@Transactional,这时你想先保存Order,然后直接在这个Transaction里保存OrderItem,但是OrderItem需要新建的Order的ID,这时候保存Order就可以用saveAndFlush,你的Entity就会有保存在数据里的id了。

讲到这儿,一些小伙伴就已经明白了,但是还有些萌新可能会被Transaction给蒙住。

Transaction是数据库提供的服务,跟spring啥的没啥关系,spring只是按照数据库厂商提供的规范封装扩展了一下。

所以想要理解save和saveAndFlush原理的,可以先去数据里试下Transaction,原来就是set auto_commit = 0; commit,rollback。

所有这里的flush就是commit的意思。

Spring Data JPA高并发下,使用save()发现无论怎么同步锁都会出现数据误差,后来换成saveAndFlush()方法结果对了,以此推断save()方法具有延迟性。