外键的作用

来源:互联网 发布:linux 截断二进制文件 编辑:程序博客网 时间:2024/04/27 15:43

 

今天我看到

“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选项创建外键约束!
============================================
原创粉丝点击