10.9. 在两个不同数据库间复制对象
优质
小牛编辑
140浏览
2023-12-01
偶尔会用到不重新生成持久化标识(identifier),将持久实例以及其关联的实例持久到不同的数据库中的操作。
//retrieve a cat from one database
Session session1 = factory1.openSession();
Transaction tx1 = session1.beginTransaction();
Cat cat = session1.get(Cat.class, catId);
tx1.commit();
session1.close();
//reconcile with a second database
Session session2 = factory2.openSession();
Transaction tx2 = session2.beginTransaction();
session2.replicate(cat, ReplicationMode.LATEST_VERSION);
tx2.commit();
session2.close();
ReplicationMode
决定在和数据库中已存在记录由冲突时,replicate()
如何处理。
ReplicationMode.IGNORE
:当某个现有数据库记录具有相同标识符时忽略它ReplicationMode.OVERWRITE
:用相同的标识符覆盖现有数据库记录ReplicationMode.EXCEPTION
:当某个现有数据库记录具有相同标识符时抛出异常ReplicationMode.LATEST_VERSION
:如果当前的版本较新,则覆盖,否则忽略
这 个功能的用途包括使录入的数据在不同数据库中一致,产品升级时升级系统配置信息,回滚 non-ACID 事务中的修改等等。(译注,non-ACID,非 ACID;ACID,Atomic,Consistent,Isolated and Durable 的缩写)