http://hi.baidu.com/voll_shallen/blog/item/9abbe73e463e3ec97d1e718e.html
以前用数据库,一般都建表关系,但是这些关系建好了往往没有用到.
这次写一个项目,涉及到多表的外键约束和级联删除的问题,才研究了一下.
用的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.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述