我一直在使用spring-data开发RESTful Web服务。几天前,发布了一个特殊的spring-data jpa REST框架。
现在,我注意到可以在此框架中使用@Version了。该版本是自己生成的还是您需要手动执行?
可以单独使用@Version吗?(这样我就不必对现有的存储库/域等进行任何更改。)
我需要做一些额外的配置来使用@Version吗?
自从我发布这个问题已经有一段时间了,但是我已经弄清楚了。我将解释自己的工作,以便对他人有所帮助。
注释@Version是一个javax.persistence接口,而不是我前面提到的spring-data rest jpa框架。
@Version
如果要使用@Version,则需要在域对象中创建一个version字段,如下所示:
@Version @Column(name = "VERSION") private long version;
如果您使用的是hibernate模式,它将自动提取注释,并在您的表(以MySql为例)中创建一个“版本”行。每次更新记录时,hibernate状态都会使计数器增加1。
现在为什么要这样?嗯,您之所以想使用它,是因为它减少了客户处理陈旧数据的机会。每当客户从您那里检索信息时,就会向他提供他请求的数据的版本。例如
{ <-- School entity --> "id": 1, "version": 0, "name": "De regenboog", "street": "Plantaanstraat", "number": "2", "zipCode": "1234AS", "city": "Amsterdam" }
现在,如果客户想要更改有关此特定记录的某些信息,它将发送新信息以及版本值。在这种情况下,让我们更改学校的名称。
{ <-- School entity --> "id": 1, "version": 0, "name": "Stackoverflow", "street": "Plantaanstraat", "number": "2", "zipCode": "1234AS", "city": "Amsterdam" }
Hibernate提供了一个查询您的信息,并添加了一个额外的“ where”子句来检查版本。update .... where id = 1 and version = 0。现在,如果该行已更新,则意味着您提供了正确的版本,并且在您请求信息,更改信息并将其发送回之间,没有其他人更改过该特定信息。不错吧?
update .... where id = 1 and version = 0
现在,如果该行未更新怎么办?这意味着在您请求信息后,在您快速洗手间时,其他人更新了该行。这意味着您的版本已过时!现在需要发生的事情实际上是特定于用例的,因此我将不赘述:)
希望有人可以使用此信息!
谢谢大家