今天我看到
“custID肯定就是来源于customer表的,因为这些custID会被提取到前台客户端的某个窗体的一个组合框中”
=======================================
http://www.oracle.com.cn/viewthread.php?tid=48702
Alter TABLE Sales add Constraint FK_sales_CustID foreign KEY(CustID) REFERENCES customer(CustID)
sales表引用了customer表的custID作为外键,如果在Customer表删除一个CustID,那么sales表会发生什么呢?这个约束我不太理解。
其实就是如果设计基础资料类型表和业务表之间的关系,我不知道是不是应该在这两者之间加上引用。如果不加上外键,在 sales表录入的时候, custID肯定就是来源于customer表的,因为这些custID会被提取到前台客户端的某个窗体的一个组合框中,但是,如果想删除一个customer表中的custID,会出现一些问题,我的想法当客户信息变更的时候不作删除,只是加上一个‘封存’标志。对于录入错误一定要删除这个客户的custID时,要先在sales表中查询是不是已经引用,才能删除成功,也可以加一个标志位限制删除操作。
=========================================
外键是与你的业务有关的,保证数据符合你的业务。
就你上面的来说如果在Customer表删除一个CustID,那么sales表会发生什么呢?
要分两种情况来说
1.sales表没有对应的记录,则在Customer表删除一个CustID不会报错。
2.sales表有对应的记录,则在Customer表删除一个CustID会报错。
解决办法有2:
a) 先删sales中的相应的记录
b) 使用delete cascade选项创建外键约束!
就你上面的来说如果在Customer表删除一个CustID,那么sales表会发生什么呢?
要分两种情况来说
1.sales表没有对应的记录,则在Customer表删除一个CustID不会报错。
2.sales表有对应的记录,则在Customer表删除一个CustID会报错。
解决办法有2:
a) 先删sales中的相应的记录
b) 使用delete cascade选项创建外键约束!
============================================