002 数据库主外键之NULL值

2024-09-01 16:32
文章标签 数据库 null 002 主外键

本文主要是介绍002 数据库主外键之NULL值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

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

概念模型到物理模型

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

 


转换成物理模型:


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

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

 

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

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

 

设置外键NULL值具体操作

1、新建数据库关系图:


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

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

 

 数据库约束慎用

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

这篇关于002 数据库主外键之NULL值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127459

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员

MybatisPlus中removeById删除数据库未变解决方案

《MybatisPlus中removeById删除数据库未变解决方案》MyBatisPlus中,removeById需实体类标注@TableId注解以识别数据库主键,若字段名不一致,应通过value属... 目录MyBATisPlus中removeBypythonId删除数据库未变removeById(Se

在 Spring Boot 中连接 MySQL 数据库的详细步骤

《在SpringBoot中连接MySQL数据库的详细步骤》本文介绍了SpringBoot连接MySQL数据库的流程,添加依赖、配置连接信息、创建实体类与仓库接口,通过自动配置实现数据库操作,... 目录一、添加依赖二、配置数据库连接三、创建实体类四、创建仓库接口五、创建服务类六、创建控制器七、运行应用程序八

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结