热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

数据库主外键之NULL值

数据库中主外键是为了保证数据库的完整性而存在的。当一个表中存在外键,就说明此表受约束,那么我们在对数据库数据进行操作时就应该注意了,刚开始学习数据库时,总想着多用,主键,外键,等一些约束,能加的都加上了,做系统的时候发现了很多错误。像级联

数据库中主外键是为了保证数据库的完整性而存在的。当一个表中存在外键,就说明此表受约束,那么我们在对数据库数据进行操作时就应该注意了,刚开始学习数据库时,总想着多用,主键,外键,等一些约束,能加的都加上了,做系统的时候发现了很多错误。像级联

数据库中主外键是为了保证数据库的完整性而存在的。当一个表中存在外键,就说明此表受约束,那么我们在对数据库数据进行操作时就应该注意了,刚开始学习数据库时,总想着多用,主键,外键,等一些约束,能加的都加上了,做系统的时候发现了很多错误。像级联删除,添加数据受外键约束等之类的事情就会出现,所以数据库中的主外键一定要慎用。

从开始做系统到现在一直使用的都是Sql server。可是也只是使用一一些大路边的功能。合作版开发的时候,第一次正式的重视对数据库。严格按照软件工程的流程,从概念模型到物理模型 ,再到数据库表的建立。也是用了一些专业的数据库设计软件,例如:powerdesigner 。概念模型设计好后,需要转换成物理模型。

概念模型到物理模型

机房收费系统中有几张表:消费表,退卡表,充值表,账单表。结账的时候,我们对消费表,充值表,退卡表中未结账的信息进行汇总统计,得出数据,插入到账单表中,结账后,把把三个表中的数据再标记为已结账。它们之间的关系多对一,存在外键约束。如图:


转换成物理模型:


概念模型转换成物理模型,概念模型中存在的外键约束在物理模型中表现在消费表,充值表,退卡表中的”结账标号“。结账编号是账单表中的主键。这样消费表,退卡表,充值表,账单表保证了数据库之间的完整性。

问题是:外键表中的数据是先插入进去的,而账单表中的数据是后插入的,这就意味着我们在插入外键表记录时,”结账标号“是不存在的,但是外键约束,我们在插入数据时,外键必须是已经存在的主键。

我们可不可以在插入记录的时候使外键为”NULL“呢?

在Sqlserver 中直接建立外键约束,插入记录外键为”NULL“是不允许的,从数据库库关系图中建立外键,再进行”NULL“值的设置,便大功告成了。

设置外键NULL值具体操作

1、新建数据库关系图:


2、选中表,右击,表视图——标准,关系图如下:

3、在图中红色区域中设置NULL值:下图中,新闻评论表的外键”新闻标题“是新闻表中的主键,这里设置为可以为”NULL“。在进行数据库插入时就可以插入外键为NULL值了。

数据库约束慎用

大家一起讨论都有同感,所以在使用数据库约束,主外键之类时,要根据具体情况来分析,系统不大,对数据的要求不是很严格,我们就可以少一些约束,这样方便系统的操作和运行;系统对数据库要求较严格,我们就必须严格按照三范式,必要的主外键,约束要加上,保证数据的完整性。

推荐阅读
  • 开发笔记:新手DVWACSRF
    开发笔记:新手DVWACSRF ... [详细]
  • 本文介绍了如何在PL/SQL中定义和使用包含多个字段的数组类型变量。首先通过一个简单的例子展示如何定义单字段数组,然后进一步扩展到多字段数组的应用。 ... [详细]
  • ThinkPHP 文件缓存组件详解与应用
    本文深入探讨了ThinkPHP框架中的文件缓存类实现,提供了详细的代码示例和使用说明,旨在帮助开发者更好地理解和利用这一功能来优化应用程序性能。 ... [详细]
  • 本文档详细介绍了服务器与应用系统迁移的策略与实施步骤。迁移不仅涉及数据的转移,还包括环境配置、应用兼容性测试等多个方面,旨在确保迁移过程的顺利进行及迁移后的系统稳定运行。 ... [详细]
  • SonarQube配置与使用指南
    本文档详细介绍了SonarQube的配置方法及使用流程,包括环境准备、样本分析、数据库配置、项目属性文件解析以及插件安装等内容,适用于具有Linux基础操作能力的用户。 ... [详细]
  • 解决PHP与MySQL之间的编码不匹配问题
    探讨如何有效解决PHP与MySQL之间常见的编码问题,确保数据的正确传输与显示。 ... [详细]
  • 使用Docker部署Gitea自托管Git服务
    Gitea是由Gogs社区分叉而来的开源自托管Git服务,旨在提供一个更加灵活和易于维护的解决方案。本文将详细介绍如何利用Docker容器技术快速部署Gitea。 ... [详细]
  • Oracle 数据库提供了自动化文件管理(OFM)的功能,允许用户通过设置特定参数来简化数据文件和日志文件的创建过程。当配置了 db_create_file_dest 和 db_create_online_log_dest_n 参数后,系统能够自动处理文件的创建与删除。 ... [详细]
  • 本文档整理了公司内部常用的网站链接和重要资源路径,包括部门周报、内控报销系统、邮件服务等,同时提供了相关数据库的登录信息。 ... [详细]
  • 深入理解Hibernate延迟加载机制
    本文探讨了Hibernate框架中的延迟加载(懒加载)特性,分析其对程序性能的影响及实现原理,同时提供了具体的代码示例来说明如何配置和使用延迟加载。 ... [详细]
  • 1、服务器配置信息① 主服务器IP:192.168.1.2② 从服务器IP:192.168.1.3③ 操作系统:主服务器:Win8,从服务器࿱ ... [详细]
  • 睿智汇海教育致力于培养杰出的IT专业人才,确保学员在就业市场上具备竞争力,助其实现职业成功。我们提供的C#/.Net/Asp.Net培训课程,旨在通过系统的教学和丰富的实践机会,帮助学员掌握最新的技术知识。 ... [详细]
  • 统一幻灯片标题:使用母版功能的技巧
    本文详细介绍了如何通过PowerPoint中的幻灯片母版功能,实现所有幻灯片标题的一致性设置。同时,提供了其他办公软件和编程相关的实用技巧。 ... [详细]
  • MySQL 5.7 绿色版安装及 my.ini 配置详解
    本文主要针对最近因系统重装导致的MySQL配置问题,详细介绍了MySQL 5.7.24绿色解压版的安装步骤及my.ini配置文件的关键设置,帮助用户顺利完成数据库的安装与配置。 ... [详细]
  • 本文介绍如何利用JavaScript在页面加载时为ASP.NET的DropDownList控件设置特定的选项值。 ... [详细]
author-avatar
諾言DJ_791
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有