SQL反模式学习笔记5 外键约束【不用钥匙的入口】
目标:简化数据库架构
一些开发人员不推荐使用引用完整性约束,可能不使用外键的原因有一下几点:
1、数据更新有可能和约束冲突;
2、当前的数据库设计如此灵活,以至于不支持引用完整性约束;
3、数据库为外键建立的索引会影响性能;
4、当前使用的数据库不支持外键。比如MySQL的MyISAM存储引擎,或者比SQLite3.6.19早的版本;
5、定义外键的语法并不简单,还需要查阅。
反模式:无视约束,即不使用约束
省略外键约束能使得数据库设计更加简单、灵活,或者执行更加高效,但是你不得不在其他方面付出相应的代价,
必须增加额外的代码来手动维护引用完整性。
1、假设无暇代码:要避免在没有外键约束的情况下产生引用的不完整状态,需要再任何改变生效前执行额外的Select查询,
以此来确保这些改变不会导致引用错误。比如在查询一条记录之前,需要检查对应的被引用记录是否存在。
2、检查错误:开发人员使用外部脚本来检查错误的数据。
3、修改代码时,无法保证系统中的所有部分都被同时修改。
4、可能有些用户直接操作了数据库,修改或删除被引用的字段值,导致其他表引用发生未知错误;
而且你不能确定所有的应用程序或者脚本在访问数据库时所做的操作都是正确合理的。
5、当你Update更新一条被其他记录依赖的记录时,在没有更新父记录前,你不能更新子记录,
而且也不能在更新父记录前更新子记录。你需要同步执行两边的更新,但是使用2个独立的更新语句是不显示的。
如何识别反模式:当出现以下情况时,可能是反模式
1、我要怎么写这个查询来检查一个值是否没有被同时存在2张表中?(通常这样的需求是为了查找那些孤立的行数据)
2、有没有一种简单的方法来判断在一张表中的数据是否也在第二张表中存在?
(这么做是用来确认父记录切实存在。外键会自动完成这些,并且外键会使用这父表的索引尽可能的高效完成)
3、有人说不要用外键,外键影响数据库效率。
合理使用反模式:
如果数据库产品不支持外键约束功能,则不得不使用别的方法来保持引用完整性,比如使用监控脚本。
同样也存在一些极度灵活的数据库设计,外键无法用来表示其对应的关系。
解决方案:声明约束
1、通过使用外键来确保应用完整性;
使用约束时:(1)数据库本身会拒绝所有不合理的改变,无论这个改变是通过什么方式造成的。
(2)能够避免编写不必要的代码,同时还能确保一旦修改了数据库中的内容,所有的代码依旧能够用同样的方式执行。
(3)外键的特性:级联更新,比如:On Update Cascade、On Delete Restrict等。
在执行更新和删除2个操作中的任意1个是,数据库都会自动修改多张表中的数据,
外键的引用状态在操作之前和之后都保持完好。
2、外键约束的确需要多那么一点额外的系统开销,但相比于其他的一些选择,外键确实更高效一点:
(1)不需要在更新或删除记录前执行Select检查;
(2)在同步修改时不需要再锁住整张表;
(3)不再需要执行定期监控脚本来修正不可避免的孤立数据。
SQL反模式,系列学习汇总
成在管理,败在经验;嬴在选择,输在不学! 贵在坚持!
个人作品
BIMFace.SDK.NET
开源地址:https://gitee.com/NAlps/BIMFace.SDK
系列博客:https://www.cnblogs.com/SavionZhang/p/11424431.html
系列视频:https://www.cnblogs.com/SavionZhang/p/14258393.html
技术栈
1、Visual Studio、.NET Core/.NET、MVC、Web API、RESTful API、gRPC、SignalR、Java、Python
2、jQuery、Vue.js、Bootstrap、ElementUI
3、数据库:分库分表、读写分离、SQLServer、MySQL、PostgreSQL、Redis、MongoDB、ElasticSearch、达梦DM
4、架构:DDD、ABP、SpringBoot、jFinal
5、环境:跨平台、Windows、Linux、Nginx
6、移动App:Android、IOS、HarmonyOS、微信小程序、钉钉、uni-app、MAUI
分布式、高并发、云原生、微服务、Docker、CI/CD、DevOps、K8S;Dapr、RabbitMQ、Kafka、RPC、Elasticsearch。
欢迎关注作者头条号 张传宁IT讲堂,获取更多IT文章、视频等优质内容。
出处:www.cnblogs.com/SavionZhang
作者:张传宁 技术顾问、培训讲师、微软MCP、系统架构设计师、系统集成项目管理工程师、科技部创新工程师。
专注于企业级通用开发平台、工作流引擎、自动化项目(代码)生成器、SOA 、DDD、 云原生(Docker、微服务、DevOps、CI/CD);PDF、CAD、BIM 审图等研究与应用。
多次参与电子政务、图书教育、生产制造等企业级大型项目研发与管理工作。
熟悉中小企业软件开发过程:可行调研、需求分析、架构设计、编码测试、实施部署、项目管理。通过技术与管理帮助中小企业实现互联网转型升级全流程解决方案。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如有问题,可以通过邮件905442693@qq.com联系。共同交流、互相学习。
如果您觉得文章对您有帮助,请点击文章右下角【推荐】。您的鼓励是作者持续创作的最大动力!