繁体   English   中英

JPA id生成通用策略

[英]JPA id generation generic strategy

我有一个正确使用JPA-Hibernate与MySQL的应用程序。 在这种情况下,我正在使用实体中的id生成一个自动策略。 另一方面,我有其他使用Oracle的应用程序,我正在使用序列策略。 关键是我想知道是否可以为Oracle / MySQL / Sql Server使用“通用”策略,并使我的应用程序更具可移植性。

谢谢。

便携式解决方案的简便方法是使用TableGenerator 值在数据库表中进行管理,并使用SQL查询进行检索和修改,因此不使用任何数据库供应商特定的结构。

不依赖于特定数据库功能的通用策略需要额外的表来生成ID。 这样的策略: hiloenhanced-table 您还可以使用基于UUID生成的策略,例如uuid.hexuuiduuid2 其他策略将使用不同的DB特定功能,因此行为可能不同。 例如, native在MySQL和Postgres中的工作方式不同,在MySQL(生成器)中,当您保存对象时,您可以正确插入,在Postgres(序列)中,您只能在常规刷新时插入。 您可能需要查看DefaultIdentifierGeneratorFactory来源以查看所有可能的策略并探索其算法和文档。

请注意,通常使用同一个数据库制作2个或更多个异构应用程序是个坏主意,特别是如果它们都在写入数据库。 您的数据库将很难维护和重构。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM