T SQL中建立表与表关系的语句问题.(菜鸟问题在线等)

来源:百度知道 编辑:UC知道 时间:2024/06/07 19:40:19
刚学到利用T SQL语句建立表与表之间的属性关联,是利用
FOREIGN KEY REFERENC语句
我想问这里和利用企业管理器建立表与表的关系图是不是一样的啊,如果不是这又是什么啊?具体有怎么用啊?

可以确保数据完整性,有A表,B表。A的主码id是B的外码。这会产生2个情况,建立外码的时候会有“级联删除”和“受限删除”两种。外码的作用就体现在这两种功能上。
级联删除:当删除A里的数据后,B表内含该ID的行会自动由数据库删除。比如把某个学生ID删除了,那么他的分数之类的信息也要删除,留着也是垃圾数据。
受限删除:当要删除A内的数据,而B中又存在相关id的行,那么将不会执行删除,必须先把B内的这些行删除掉,再删除a里的数据。
更加详细的你可以去看MSsql联机丛书关于级联删除等的介绍。以下来自sql联机丛书:
ON DELETE NO ACTION

指定如果试图删除某行,而该行含有由其它表的现有行中的外键所引用的键,则产生错误并回滚 DELETE。

ON UPDATE NO ACTION

指定如果试图更新某行中的键值,而该行含有由其它表的现有行中的外键所引用的键,则产生错误并回滚 UPDATE。

CASCADE 允许在表间级联键值的删除或更新操作,这些表的外键关系可追溯到执行修改的表。不能为任何具有 timestamp 列的外键和主键指定 CASCADE。

ON DELETE CASCADE

指定如果试图删除某行,而该行含有由其它表的现有行中的外键所引用的键,则也将删除所有包含那些外键的行。如果在目标表上也定义了级联引用操作,则对从那些表中删除的行同样采取指定的级联操作。

ON UPDATE CASCADE

指定如果试图更新某行中的键值,而该行的键值由其它表的现有行中的外键所引用,则所有外键值也将更新成为该键指定的新值。如果在目标表上也定义了级联引用操作,则对在那些表中更新的键值同样采取指定的级联操作。

上面就是外码约束的概念,希望你能明白它的作用.我都是手写sql建表的,呵呵~企业管理器用不习惯。