Intershop EDL 建模 - 如何通过级联删除添加依赖性
Intershop EDL modelling - How to add dependency with on cascade delete
我们有一些通过 EDL 建模的自定义对象,它们具有系统 Intershop 对象(ISPRODUCT 和 ISORDER)的外键。当引用的订单或产品被删除时,我们需要我们的对象被删除。
这是 EDL 文件的摘录:
/**
* Relation to product PO (tariff item)
*/
dependency tariff: ProductPO
{
foreign key(tariffID);
}
/*
* Order relation
*/
dependency order: OrderPO
{
foreign key(orderID);
}
如我所见,可以在 EDL 关系上添加删除操作,但不能在依赖项上添加删除操作。
我们目前正在做的是像这样修改生成的 dbconstraints.oracle.ddl 文件中的语句:
EXEC staging_ddl.add_constraint('A1APPLICATIONFORM', 'A1APPLICATIONFORM_CO_003', 'FOREIGN KEY (TARIFFID) REFERENCES PRODUCT (UUID) ON DELETE SET NULL INITIALLY DEFERRED DEFERRABLE DISABLE NOVALIDATE');
EXEC staging_ddl.add_constraint('A1APPLICATIONFORM', 'A1APPLICATIONFORM_CO_004', 'FOREIGN KEY (ORDERID) REFERENCES ISORDER (UUID) ON DELETE CASCADE INITIALLY DEFERRED DEFERRABLE DISABLE NOVALIDATE');
但这只是临时解决方法,因为每次我们在 EDL 上重新启动代码生成器时,这些文件都会被覆盖。
关于关系,可以像这样定义删除操作:
relation promotionBenefitPOs : A1PromotionBenefitPO[0..n] inverse promotionPO implements promotionBenefits delete default;
是否可以在系统对象的依赖上实现同样的事情?
恐怕您需要手动完成。这意味着一旦所涉及类型的一个实例被删除,您需要查询您的自定义粘合对象并通过您自己的后续操作删除该对象。由于依赖只是一个弱(单向)关系,orm 无法自动删除。
有关 EDL 依赖性的文档,请参阅此处:https://support.intershop.com/kb/index.php/Display/247P28
例如,我检查了ProcessPagelet-Delete pipline。在那里我们首先取消分配(即删除分配)Label
对象从Pagelet
被删除。 PageletLabelAssingmentPO
包含对 Pagelet
的依赖性,如您在此处所见:
orm class PageletLabelAssignmentPO extends LabelAssignmentPO
{
attribute pageletUUID : uuid;
dependency pagelet : PageletPO
{
foreign key(pageletUUID);
}
}
我不知道 EDL 可以做到这一点,很高兴知道。我对这种方法的问题是,orm 缓存不知道这些对象正在被 oracle 删除,因此它可能有幻像对象在 orm 缓存中浮动。
我会使用这个 register listener 解决方案来删除这些对象,以便更新所有内容并将其从缓存中清除。
我确实想知道代码生成器如何处理关系上的删除 属性。
我们有一些通过 EDL 建模的自定义对象,它们具有系统 Intershop 对象(ISPRODUCT 和 ISORDER)的外键。当引用的订单或产品被删除时,我们需要我们的对象被删除。
这是 EDL 文件的摘录:
/**
* Relation to product PO (tariff item)
*/
dependency tariff: ProductPO
{
foreign key(tariffID);
}
/*
* Order relation
*/
dependency order: OrderPO
{
foreign key(orderID);
}
如我所见,可以在 EDL 关系上添加删除操作,但不能在依赖项上添加删除操作。
我们目前正在做的是像这样修改生成的 dbconstraints.oracle.ddl 文件中的语句:
EXEC staging_ddl.add_constraint('A1APPLICATIONFORM', 'A1APPLICATIONFORM_CO_003', 'FOREIGN KEY (TARIFFID) REFERENCES PRODUCT (UUID) ON DELETE SET NULL INITIALLY DEFERRED DEFERRABLE DISABLE NOVALIDATE');
EXEC staging_ddl.add_constraint('A1APPLICATIONFORM', 'A1APPLICATIONFORM_CO_004', 'FOREIGN KEY (ORDERID) REFERENCES ISORDER (UUID) ON DELETE CASCADE INITIALLY DEFERRED DEFERRABLE DISABLE NOVALIDATE');
但这只是临时解决方法,因为每次我们在 EDL 上重新启动代码生成器时,这些文件都会被覆盖。
关于关系,可以像这样定义删除操作:
relation promotionBenefitPOs : A1PromotionBenefitPO[0..n] inverse promotionPO implements promotionBenefits delete default;
是否可以在系统对象的依赖上实现同样的事情?
恐怕您需要手动完成。这意味着一旦所涉及类型的一个实例被删除,您需要查询您的自定义粘合对象并通过您自己的后续操作删除该对象。由于依赖只是一个弱(单向)关系,orm 无法自动删除。 有关 EDL 依赖性的文档,请参阅此处:https://support.intershop.com/kb/index.php/Display/247P28
例如,我检查了ProcessPagelet-Delete pipline。在那里我们首先取消分配(即删除分配)Label
对象从Pagelet
被删除。 PageletLabelAssingmentPO
包含对 Pagelet
的依赖性,如您在此处所见:
orm class PageletLabelAssignmentPO extends LabelAssignmentPO
{
attribute pageletUUID : uuid;
dependency pagelet : PageletPO
{
foreign key(pageletUUID);
}
}
我不知道 EDL 可以做到这一点,很高兴知道。我对这种方法的问题是,orm 缓存不知道这些对象正在被 oracle 删除,因此它可能有幻像对象在 orm 缓存中浮动。
我会使用这个 register listener 解决方案来删除这些对象,以便更新所有内容并将其从缓存中清除。
我确实想知道代码生成器如何处理关系上的删除 属性。