sql server 外键 更新(删除)规则
来源:互联网 发布:淘宝返现短信怎么写 编辑:程序博客网 时间:2024/06/10 01:39
设定外键为级联删除就可以了。alter table B add constraint fk_ID foreign key (ID) references A(ID) on delete cascade;这样只需:delete from A where ID=nnnn; 就可以自动删除对应B表内容了。通过外键无法实现同步更新。
以前用数据库,一般都建表关系,但是这些关系建好了往往没有用到.
这次写一个项目,涉及到多表的外键约束和级联删除的问题,才研究了一下.
用的vs2005里面自带的SqlExpress,在VS里面作数据库,感觉不是很方便(废话,都方便了,那sqlserver2005 dev 卖给谁去!)
我建了表,然后建了关系,设定了外键约束.
然后就以为万事大吉了,去写代码,画界面去了.
把代码和界面搞定后,一试验删除,删除的级联链中间的一个表的数据,然后就报错.
然后研究了下外键约束.到底是怎么回事.网上搜到一篇定义:
仍然不解其意.
然后在关系图中的关系上点击右键,查看属性,发现其"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.删除的时候好办,级联删除就可以了.但更新的时候还得好好考虑.
b.或者干脆去掉外键约束,自己考虑,然后写transcation sql.
- sql server 外键 更新(删除)规则
- sql server 外键 更新(删除)规则
- sql server 外键 更新(删除)规则
- 【SQL server】更新与删除
- SQL Server 批量更新和级联删除(批量删除)
- SQL SERVER 规则的创建、绑定、解绑、删除
- SQL, sql server 2000 ,表间数据 ,级联更新删除
- SQL, sql server 2000 ,表间数据 ,级联更新删除
- SQL, sql server 2000 ,表间数据 ,级联更新删除
- Sql Server排序规则(转)
- SQL Server非正常删除日志文件(ldf)恢复方法(待更新)
- SQL server数据库检索记录,编辑记录(添加,更新,删除)实例
- sql server 排序规则
- SQL Server 设计规则
- SQL Server 排序规则
- SQL Server:命名规则
- SQL Server 排序规则
- SQL Server排序规则
- xcode在调试时无法查看变量值
- Nim取子游戏
- FTP 命令模式下 PASV OR PORT
- windows 和 linux 互传文件
- Tomcat 报错:Exception starting filter struts2
- sql server 外键 更新(删除)规则
- jQuery 入门教程(2): Selectors
- 存储过程在sqlplus中的操作
- 查看端口命令
- 关于mysql函数GROUP_CONCAT
- ssh框架中事务管理配置
- json.dumps错误:'utf8' codec can't decode byte解决方案
- USACO section 3.4 American Heritage(二叉树序列)
- sql表复制,常用语句