当前位置: 首页 > news >正文

【MySQL】数据库必备知识:全面整合表的约束与深度解析

        前言:本节内容讲述表的约束的相关内容。 表的约束博主将会通过两篇文章进行讲解, 这是第一篇上半部分。 讲到了约束概念。 以及几种常见约束。下面友友们开始学习吧!

        ps:友友们使用了mysql就可以放心观看喽!

目录

表的约束概念

非空约束

 default默认值

default

非空和默认的区别   

列描述

zerofill

主键

去掉主键       

建表后添加主键

多列主键


表的约束概念

        表的约束要让用户在数据库当中安全的插入数据, 就必须要有表的约束。 否则就比如我们的这个表的这一行信息应该插入性别, 但是有没有用户在上层插入了一个人名呢? ——所以, 为了避免这些问题。表中就要有各种约束, 通过约束, 让我们未来插入数据库表中的数据是符合预期的。 

        约束本质是通过技术手段倒逼程序员插入正确的数据。反过来站在mysql的角度, 凡是插入进来的数据都是符合数据约束的。

        约束的最终目标就是保证数据的完整性和可预期性。 

        综上, 所以为了能够更好的使用数据库, 我们就需要更多的约束条件

非空约束

        NULL VS '  '这两个有什么区别呢? 其中'   '并不是什么都没有, 而是表示插入的是一个空串, 是一个字符串, 只不过这个字符串是空的。 而NULL是什么都没有。 (NULL是不参与运算的。)

        非空约束有两个:一个是null(默认的为空) 和 not null(不为空)。什么意思, 就是说我们建表的时候,如果不带null和not null。 那么默认的就是null, 也就是该列属性可以为空。 而如果我们想要让该列属性不能为空, 就必须添加一个not null。 

        下面为例子:

create table if not exists class(class_name varchar(20) not null,
class_room varchar(20) not null,
other varchar(20) 
);

        desc后的显示结果中有一列: Null,下面有的是NO, 有的是YES。  这里的NO就是不允许为空。 如果插入空, 那么就报错:

insert into class values(null, 103, 104);
insert into class values(103, null, 104);
insert into class values(103, 103, 104);

 default默认值

default

        default是默认值, 就比如说我们在插入数据的时候, 有可能某一列没有插入数据, 那么这个时候如果有默认值, 这个列就能自动的插入一个默认值。

        下面为示例:

mysql> create table if not exists t13(-> name varchar(20) not null,-> age tinyint unsigned default 18,-> gender char(1) default '男'-> );

        然后我们就能看到上面的我们没有设置not null的就是默认可以为空。 然后后面有一个Default, 这个Default默认是NULL, 空没有默认值。 然后我们设置后, 就出现了默认值18或者男。

       只插入name, 然后age和gender都被插入了默认值。  

非空和默认的区别   

    接下来测试非空和默认的区别:

mysql> create table if not exists t14(-> name varchar(20) not null,-> age tinyint default 18,-> gender char(1) not null default '男'-> );

我们先测试name:

        这里我们首先插入了一个NULL,给我们报错是不能为空。 这符合我们的语气,因为NULL就是代表空。 而name不能为空, 所以会报错。

        问题是第二个报错。 我们对name列没有进行插入, 但是他报错了没有默认值。 ——所以, 这里就有一个结论: 如果我们某一列设置了not null, 那么我们没有明确指定一列要插入, 用的就是default,如果建表中对应列默认没有设置default, 无法直接插入。

        gender既有not null, 又有default, 所以按照刚刚的结论就应该可以插入:

        可以观察到插入成功。

        所以default 和 NOT NULL不冲突, 而是互相补充的。当用户想插入的时候, 就是NULL和NOT NULL来约束(插入NULL 、合法数据、不合法数据) ;当用户忽略这一列的时候, 就是使用default来约束:如果设置了就是使用默认值。 如果没有设置, 那么就会报错!!!。

        但是, 我们之前插入的时候, 明明是可以忽略某一列的啊, 就比如下面这样:

        我们创建一个表, 这个表当中三列, 都没有设置默认值。 但是我们也可以忽略gender这一列啊。 这是为什么呢? 是不是上面我们的结论出错了呢? ——答案是不是的。 这是因为mysql在我们创建表的时候做了优化, 如果我们不带默认值, 他就会默认给我们添加默认值NULL:

列描述

        列描述就相当于对表当中的字段进行说明。就是一种描述字段。并没有说如果不符合规则就不让插入。 

mysql> create table if not exists t16(-> name varchar(20) not null comment'这个是用户的用户名',-> age tinyint unsigned default 18 comment '这个是用户的年龄',-> gender char(1) not null default '男' comment '这个是用户的性别'-> );

zerofill

        zerofill其实就是将数据的所有位全部用0填充,格式化显示。就是如果插入的数据的宽度小于限定的宽度, 那么就补零。如果超出了宽度, 那么就要原本的数据位数。 

        下面为示例:

create table t18( a int unsigned zerofill, b int unsigned );

        上面可以看到我们使用zerofile创建的a变量, int类型是申请了10个空间。 然后我们插入一些数据:

然后我们就能看到, a这里除了一个1, 前面的位都被0填满了。 

主键

        主键约束就是我们在建表的时候, 有一列信息标定该一条信息的唯一性,并且这一列信息不能为空。也就是主键列不能重复, 不能为空。 一张表中最多只能有一个主键。主键所在的列通常是整型类型。

         下面为示例:

mysql> create table if not exists test_key(-> id int unsigned primary key comment '这个是学生的学号',-> name varchar(20) not null,-> gender char(1) -> );


        通过上面的例子我们观察, 其中我们的id是一个主键列, 这个id的Key的位置被设置成为了PRI,意思就是主键列。 然后Null变成了不能为空。 这个是主键列的性质。

        插入的时候我们的id重复, 就会报错!!

去掉主键       

alter table 表名 drop primary key;

然后就能重复插入了:

建表后添加主键

alter table 表名称 add primary key(id);

 我们上面添加失败是因为id列有许多重复的元素。 所以我们想要添加主键就要将去重:

我们去重之后就能插入了。

多列主键

        一个主键可以被添加到一列或者多列, 这类多列主键叫做符合主键。

        下面为示例:

mysql> create table t19(-> id int unsigned,-> course_id int unsigned comment'课程编号',-> score tinyint unsigned comment'这个学生这门课程的分数',-> primary key (id, course_id)-> );


        我们创建好了之后, id和course_id合起来才称为一个主键。 下面我们测试插入数据:

insert into t19 values(1234, 40, 90);
insert into t19 values(1235, 40, 90);
insert into t19 values(1235, 41, 90);
insert into t19 values(1235, 40, 90);

        然后我们就能发现我们重复可以让1234选择40这门课, 1235也可以选择40这门课。 1235也可以选择41这门课。 但是1235再次选择40这门课的时候就出错了!

        所以, 多列主键就是, 列之中只要有一个数据不一样, 就可以进行插入。只有当所有数据都一样的时候才不可以插入。

  ——————以上就是本节全部内容哦, 如果对友友们有帮助的话可以关注博主, 方便学习更多知识哦!!!    


http://www.mrgr.cn/news/75089.html

相关文章:

  • 传统以太网问题与VLAN技术详解
  • Android ScrollView嵌套X5WebView大片空白问题
  • STM32之两种驱动 “旋转编码器“ 方式
  • 【数据可视化-12】数据分析岗位招聘分析
  • C++ Primer Plus第三章课后习题总结
  • flask_sqlalchemy relationship 子表排序
  • vue中重置对象的好使方式(封装好的函数,可直接食用)
  • YZ系列工具之YZ10:VBA_梦幻图像
  • Orleans Stream测试
  • 大数据新视界 -- 大数据大厂之 Impala 性能飞跃:动态分区调整的策略与方法(上)(21 / 30)
  • python语言基础-4 常用模块-4.12 namedtuple(名称元组)
  • 第12章 系统部署
  • 一道C语言关于距离的期末题及答案
  • 光伏储能微电网协调控制器
  • 20241114给荣品PRO-RK3566开发板刷Rockchip原厂的Android13下适配RJ45以太网卡
  • STM32学习笔记-----UART的概念
  • 远程开发测试必看:如何在群晖NAS上运行网页版Ubuntu
  • Docker 篇-Docker 详细安装、了解和使用 Docker 核心功能(数据卷、自定义镜像 Dockerfile、网络)
  • 三、模板与配置(上)
  • springboot学科竞赛管理(代码+数据库+LW)
  • P10901 [蓝桥杯 2024 省 C] 封闭图形个数
  • 【话题讨论】AI赋能电商:创新应用与销售效率的双轮驱动
  • 【AiPPT-注册/登录安全分析报告-无验证方式导致安全隐患】
  • python 字典 详解
  • 分享个好玩的,在k8s上部署web版macos
  • 【debug】QT 相关问题error汇总 QT运行闪退 QT5升级到QT6注意要点