sqlserver外键更新(删除)规则
以前⽤数据库,⼀般都建表关系,但是这些关系建好了往往没有⽤到.
这次写⼀个项⽬,涉及到多表的外键约束和级联删除的问题,才研究了⼀下.
⽤的vs2005⾥⾯⾃带的SqlExpress,在VS⾥⾯作数据库,感觉不是很⽅便(废话,都⽅便了,那sqlserver2005 dev 卖给谁去!)
我建了表,然后建了关系,设定了外键约束.
然后就以为万事⼤吉了,去写代码,画界⾯去了.
把代码和界⾯搞定后,⼀试验删除,删除的级联链中间的⼀个表的数据,然后就报错.
Title
DELETE 语句与 REFERENCE 约束"FK_课程扩展信息表_教师表"冲突。该冲突发⽣于
数据库"x:\xxx.MDF",表"dbo.课程扩展信息表", column '教师编号'。
语句已终⽌。
然后研究了下外键约束.到底是怎么回事.⽹上搜到⼀篇定义:
仍然不解其意.
然后在关系图中的关系上点击右键,查看属性,发现其"INSERT 和 UPDATE 规范类别 "内都是"⽆操作",感觉应该是这⾥的问题.
上msdn上搜索了⼀下,发现了这篇⽂章: 可视化数据库⼯具-外键列属性
ms-help://MS.MSDNQTR.v80.chs/MS.MSDN.v80/MS.VisualStudio.v80.chs/dv_vdt01/html/2cb23e81-6342-4390-9d0e-b7a4805eca0f.htm 关键的⼏句在这⾥:
总算是明⽩了:
1.在vs2005中,外键约束的属性窗⼝中它不叫"级联",叫"层叠",估计是翻译错误.
2.vs2005中,在关系图中建⽴外键约束,它"默认的INSERT 和 UPDATE 规范"都是"⽆操作".也就是说,你只要更新或删除,它都会报错.
3.解决的⽅法:
a.删除的时候好办,级联删除就可以了.但更新的时候还得好好考虑.
foreign key references用法
b.或者⼲脆去掉外键约束,⾃⼰考虑,然后写transcation sql.

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。