标签:database-versioning revision java
关于如何最好地实现基于Java的Web应用程序的文章修订历史并将其保存在AuditLog中的任何想法
StackOverflow已经具有这种功能,几乎可以像SVN客户端一样,使一个人看到一个版本与另一个版本之间的差异.
这更多的是设计而不是实现问题.
另外:如何将这些更改显示在网页上?
另外:建议的解决方案
Article
--------------------------------
Integer id
String title
String body
List<Tag> tags
AppUser createdBy
Date createdDate
AuditLog
--------------------------------
Integer id
Integer objectId
Operation operation // enum with UPDATE and DELETE. I won't audit an insert
Date createdDate
AppUser createdBy
String class
String revisionXML
String comment
Hibernate Interceptor将拦截
保存过程,并使用Castor XML创建旧对象的XML字符串.
类和id用于获取特定对象的修订版.
google-diff-match-patch将用于创建HTML差异文件
解决方法:
最好的解决方案是使用已经支持版本(例如Apache Jackrabbit)的数据库或存储.
如果这不是一个选择,那么您必须决定要将文章存储在何处.在文件系统上?然后将每篇文章都设为目录,并将修订版本另存为数字(00001、00002等),然后将上一个修订版本的编号放入一个特殊文件(如当前文件)中.然后,您可以快速找出有多少版本(仅查看最新版本)并前进和后退.
如果您使用数据库,则在商品表中添加一个版本号字段,并添加第二个表或一个标志,该表或标志说明当前版本是哪个.您也可以选择max(version),但这些SQL结构往往很难看且令人困惑.将这些信息保存到其他地方要简单得多.
[编辑]要生成差异,请查看以下项目:google-diff-match-patch
标签:database-versioning,revision,java 来源: https://codeday.me/bug/20191107/2002451.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。