外键的作用

 

今天我看到

“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选项创建外键约束!
============================================
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值