外键的作用
来源:互联网 发布: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选项创建外键约束!
就你上面的来说如果在Customer表删除一个CustID,那么sales表会发生什么呢?
要分两种情况来说
1.sales表没有对应的记录,则在Customer表删除一个CustID不会报错。
2.sales表有对应的记录,则在Customer表删除一个CustID会报错。
解决办法有2:
a) 先删sales中的相应的记录
b) 使用delete cascade选项创建外键约束!
============================================
- 外键的作用?
- 外键的作用
- 外键的作用
- 外键的作用
- 外键的作用
- 外键的作用
- 外键的作用
- 【外键的作用】
- 外键的作用
- 外键的作用?
- 外键的作用
- 外键的作用是什么
- sql 外键的作用
- 外键约束的作用
- [转]外键的作用
- 外键的作用是什么?
- 数据库外键的作用
- 数据库外键的作用
- 中国第三方物流需求决策研究
- 获得php.ini中的设置值
- 现代统计分析方法分类
- 第三方物流3PL/SCM系统设计技术
- 英语常用口语100句,建议打印保存
- 外键的作用
- 我的HTML太烂了(2)
- 经验分享----TCP/IP简介
- 什么是真正的程序员?
- Tangram for Internet Explorer铪铪铪
- 太阳是否还会升起?
- 承认多元化,保持宽容
- Oracle Database 11g Release 1 (11.1) Installation On Fedora 8
- Windows桌面的自由定制:关于Tangram Desktop System