我有一个数据库应用程序,其中一个组的建模如下:
TABLE Group
(
group_id integer primary key,
group_owner_id integer
)
TABLE GroupItem
(
item_id integer primary key,
group_id integer,
group_owner_id integer,
Foreign Key (group_id, group_owner_id) references Group(group_id, group_owner_id)
)
我们设置了一个多字段外键,包括group_owner_id
因为我们要确保 aGroupItem
不能拥有与Group
它所在的不同的所有者。出于其他原因(我认为我不需要详细说明) group_owner_id 不能被从GroupItem
表中删除,因此仅将其删除不是一种选择。
我的大问题是,如果我想group_owner_id
为整个组更新,我正在编写这样的代码(在伪代码中):
...
BeginTransaction();
BreakForeignKeys(group_items);
SetOwnerId(group, new_owner_id);
SaveGroup(group);
SetOwnerId(group_items, new_owner_id);
SetForeignKeys(group_items, group);
SaveGroupItems(group_items);
CommitTransaction()
...
有没有办法做到这一点?它似乎有点笨拙。希望我已经发布了足够的细节。
谢谢。