MySQL从入门到入土---MySQL表的约束 (内含实践)---详细版

目录

引入:

null 与not null

default:

comment列描述 :

not null 和 default:

zerofill :

主键:primary key

复合主键:

自增长:auto_increment

唯一键:unique key

外键:

引入:

MySQL本质上是数据的最后一道防线,它为了保证自己内部存储的数据一定是符合预期的,会针对每次插入的数据做严格检查,虽然数据类型已经算是一种约束,但是还不够灵活和全面,所以Mysql也存在其他的约束,如:null/not null,default, comment, zerofill,primary 、key,auto_incrementunique key ...

主要介绍null/not null,default, comment, zerofill,primary 、key,auto_incrementunique key 这几种约束。

null 与not null

在实际工程中,大部分情况下一般默认的数据都不会是null,因为没有意义

#新建一张表t1用于测试null
mysql> create table t1(
    -> class_name varchar(32),
    -> class_room vaechar(32)
    -> );

#插入测试数据
insert into t1(class_name) values('软件工程');

不插入class_room字段,查一下表中数据:

#查询
select* from t1;

查询结果:

很显然,在教室的数据库表中,class_room不应该出现null,class_name却存在的情况,如果不使用not null修饰,很又可能会发生上述情况,所以给字段属性设置not null后再查一次:

#重新建立表t1
mysql> create table t1(
    -> class_name varchar(32) not null,
    -> class_room varchar(32) not null
    -> );

#插入上次测试的数据

显示MySQL不允许此次插入,即要求必须要插入所有数据,不能使用默认的null值。

default:

语法和上述的not nul类似,当字段设置了default约束时,如果插入数据时,该字段对应的数据为null,则默认使用default的值

测试demo:

#创建表用来测试
mysql> create table t2_default(
    -> class_room varchar(32) not null,
    -> age tinyint unsigned default 0
    -> );

insert时,只插入class_room字段:

insert into t2_default values('软件');

查一下:

发现结果确实符合预期,age使用了建表时的默认值;

测试一下字符串:

mysql> create table t3( 
       name varchar(32) default '张三', 
       age int default 0);

 同样的insert一条数据:

mysql> insert into t3 values()
    -> ;

查一下:

varcahar同样可以使用default,其他类型同理;

comment列描述 :

在创建表时,用来描述字段;

demo测试:

mysql> create table t4(
    -> age int comment '年龄',
    -> name varchar(32) comment '姓名'
    -> );

comment的描述无法使用desc语句查询到,可以使用如下语句查询:

mysql> show create table t4 \G

结果:

符合预期;

not null 和 default:

二者可以连用,但是注意:如果我们建立表的时候两种约束一起使用,例如not null default xxx;

如果我们不在该字段插入数据,只在其余字段插入。是允许插入的;但是如果只设置了not null,MySQL是不允许我们忽略该字段,而直接插入表的其他字段的;

zerofill :

说人话:是MySQL的一种对数据的格式化显示的约束;

当表中字段带有zerofill约束时,数据类型后面的整数才有意义

demo样例,不带zerofill约束:

mysql> create table if not exists t6(
    -> num int(10) not null
    -> );

insert一条数据:

mysql> insert into t6 values(5);

查一下:

可以发现不带zerofill约束时,num字段后面带的数字好像并没有体现意义;

加上zerofill约束:

mysql> alter table t6 modify num int(10) zerofill;

再查一次:

 得出结论:如果用户插入的数据合法,但是长度不满足创建表时定义int的显示长度,会补充前导0,直到长度 == 定义表时的int显示长度;当然,字段中一定要携带有zerofill约束,若没携带,则无意义;

补充:zerofill不会改变数据本身意义,只改变显示长度!!

主键:primary key

概念:

  • 主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;
  • 主键所在的列通常是整数类

demo测试:

mysql> create table t7(
    -> id int not null primary key,
    -> name varchar(32)
    -> );

desc查一下:

insert几条数据测试结果:

mysql> insert into t7 values(1,'张三');
mysql> insert into t7 values(1,'李四');
mysql> insert into t7 values(1,'王五');
mysql> insert into t7 values(1,'小明');
mysql> insert into t7 values(1,'小美');

第一次成功插入,但是之后的插入全部被拒绝:

再测试不同的id数据插入:

mysql> insert into t7 values(2,'张三');
mysql> insert into t7 values(3,'张三');
mysql> insert into t7 values(4,'张三');

 查一下:

符合主键的描述,也符合我们的预期;

删除主键:
mysql> alter table t7 drop primary key;

再查一下表结构:

复合主键:

在创建表的时候,在所有字段之后,使用 primary key( 主键字段列表 ) 来创建主键,如果有多个字段
作为主键,可以使用复合主键
直接来个demo测试:
mysql> create table t1(
    -> id int,
    -> name varchar(32),
    -> primary key(id,name)
    -> );

连续insert2次相同的数据:

mysql> insert into t1 values(1,'张三');

第一次显示成功,第二次拦截;

验证一点:复合主键不允许相同的列组合数据插入;

第二次demo测试:

mysql> insert into t1 values(2,'张三');
mysql> insert into t1 values(3,'张三');
mysql> insert into t1 values(1,'李四');

查一下:

3次均能插入,也就是说,只要组合列中有一列数据与历史已插入数据不同即可;

自增长:auto_increment

auto_increment

来个demo样例:

mysql> create table if not exists t2(
    -> id int primary key auto_increment comment '学生id',
    -> name varchar(32)
    -> );

insert几次数据:

mysql> insert into t2 values(null,'张三');
mysql> insert into t2 values(null,'李四');
mysql> insert into t2 values(null,'王五');

插入成功,并且id全都不重复,如图:

1.auto_increment默认从1开始自增;2.也可以从最近的一次插入的数据(没插入成功的数据一样记录自增)开始自增;3.也可以建表时手动设置初始值

来个demo测试,测试第二点:

mysql> insert into t2 values(100,'王五');
mysql> insert into t2 values(null,'王五');

查一下:

 符合预期;

测试第三点:建表时可以指定auto_increment的初始值:

mysql> create table if not exists t3(
    -> id int primary key auto_increment,
    -> name varchar(32)
    -> )auto_increment=1000;

insert数据:

mysql> insert into t3 values(null,'张三');
mysql> insert into t3 values(null,'李四');

查一下:

 符合预期;

唯一键:unique key

  • 一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以 解决表中有多个字段需要唯一性约束的问题。
  • 唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。

来个demo测试:创建一个学生信息表,不允许姓名,电话号码和微信号重复;

mysql> create table student(
    -> id int unsigned primary key auto_increment comment '学生id',
    -> name varchar(20) not null unique,
    -> tel char(20) unique,
    -> wechat_id varchar(32) unique
    -> );

desc一下:

insert几次数据测试: 

mysql> insert into student values(null,'张三','123456789','xxxxxx');
mysql> insert into student values(null,'李四','123456789','xxxxxx');
mysql> insert into student values(null,'李四','12345678910','xxxxxx');
mysql> insert into student values(null,'李四','12345678910','xxxxxxyyy');

第一次insert成功,第2,3次失败,第四次成功,查一下表:符合预期;

外键:

  • 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或唯一键约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null

语法:foreign key (字段名) references 主表()

来个案例:需要一张学生表和一张班级表,其中多名学生可以隶属于同一个班级(或者待定),但是不能隶属于班级表中不存在的班级,要删除班级表中的某个班级时,要确保班级中没有学生存在;

测试:

#创建班级表
mysql> create table class(
    -> id int unsigned primary key auto_increment,
    -> name varchar(32)
    -> );

#insert班级表数据
mysql> insert into class values(null,'软件工程001');
mysql> insert into class values(null,'软件工程002');

#创建学生表
mysql> create table student(
    -> id int unsigned primary key auto_increment,
    -> name varchar(32) not null,
    -> class_id int unsigned,
    -> foreign key(class_id) references class(id)
    -> );

#insertstudent的有效数据
mysql> insert into student values(null,'张三',1);
mysql> insert into student values(null,'李四',1);
mysql> insert into student values(null,'王五',1);
mysql> insert into student values(null,'赵六',2);
mysql> insert into student values(null,'小王',null);


#测试无效数据
mysql> insert into student values(null,'田七',3);
mysql> insert into student values(null,'小明',0);


查一下表中结果:

当插入的学生class_id不在班级表的id中的,显示插入数据失败!

 符合预期;

再测试能否删除主表的数据:

从表数据存在时:

#在主表(班级表)中新增一行信息
mysql> insert into class values(null,'通信工程001');
#此时从表中没有数据是class_id = 3的,我们尝试删除这一行数据
mysql> delete from class where id=3;

#测试从表中有数据使用主表的id时能否直接删除
mysql> delete from class where id=1;
mysql> delete from class where id=2;

第一次测试时,可以直接删除,因为主表的id=3在从表中并未有数据使用!

第二次测试时,无法直接删除,因为从表中有数据使用了主表的id:

 符合预期;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/943320.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于NodeMCU的物联网窗帘控制系统设计

最终效果 基于NodeMCU的物联网窗帘控制系统设计 项目介绍 该项目是“物联网实验室监测控制系统设计(仿智能家居)”项目中的“家电控制设计”中的“窗帘控制”子项目,最前者还包括“物联网设计”、“环境监测设计”、“门禁系统设计计”和“小…

Webpack在Vue CLI中的应用

webpack 作为目前最流行的项目打包工具,被广泛使用于项目的构建和开发过程中,其实说它是打包工具有点大材小用了,我个人认为它是一个集前端自动化、模块化、组件化于一体的可拓展系统,你可以根据自己的需要来进行一系列的配置和安…

java日志框架:slf4j、jul(java.util.logging)、 log4j、 logback

SLF4J--抽象接口 SLF4J (Simple Logging Facade for Java) 是一个为各种 Java 日志框架提供简单统一接口的库。它的主要目的是将应用程序代码与具体的日志实现解耦,使得在不修改应用程序代码的情况下,可以轻松地切换不同的日志框架。 jul-to-slft4j.ja…

命令行之巅:Linux Shell编程的至高艺术(中)

文章一览 前言一、输入/输出及重定向命令1.1 输入/输出命令1.1.1 read命令1.1.2 echo命令 1.2 输入/输出重定向1.3 重定向深入讲解1.4 Here Document1.4.1 /dev/null 文件 二、shell特殊字符和命令语法2.1 引号2.1.1 双引号2.1.2 单引号2.1.3 倒引号 2.2 注释、管道线和后台命令…

一文理解机器学习中二分类任务的评价指标 AUPRC 和 AUROC

🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ 在机器学习的二分类任务中,评估模型性能是至关重要的一步。两种常用的评价指标是 Precision-Recall Curve 下的面积 (AUPRC) 和 Receiver Operating Characteristic Curve 下的面积 (AUROC)…

Visual Studio Code(VS Code)配置C/C++环境

一、Visual Studio Code安装 Visual Studio Code,下文中简称为VS Code的详细安装方法请参考VSCode安装教程(超详细)-CSDN博客 二、MinGW编译器下载与配置 1、MinGW介绍 MinGW(Minimalist GNU for Windows)是一款用于Windows 平台的轻…

少儿编程在线培训系统:客户服务与学习支持

2.1 VUE技术 VUE它是由HTML代码,配上嵌入在HTML代码里面的Java代码组成的应用于服务器端的语言,使用VUE进行开发能够更加容易区分网页逻辑以及网页设计内容,让程序员开发思路更加清晰化,VUE在设计组件时,它是可以重用的…

uniapp Native.js原生arr插件服务发送广播到uniapp页面中

前言 最近搞了个设备,需求是读取m1卡,厂家给了个安卓原生demo,接入arr插件如下,接入后发现还是少了一部分代码,设备服务调起后触发刷卡无法发送到uniapp里。 中间是一些踩坑记录,最后面是解决办法&#xf…

C项目 天天酷跑(下篇)

上篇再博客里面有&#xff0c;接下来我们实现我们剩下要实现的功能 文章目录 碰撞检测 血条的实现 积分计数器 前言 我们现在要继续优化我们的程序才可以使这个程序更加的全面 碰撞的检测 定义全局变量 实现全局变量 void checkHit() {for (int i 0; i < OBSTACLE_C…

HarmonyOS NEXT 实战之元服务:静态案例效果--航空出行

背景&#xff1a; 前几篇学习了元服务&#xff0c;后面几期就让我们开发简单的元服务吧&#xff0c;里面丰富的内容大家自己加&#xff0c;本期案例 仅供参考 先上本期效果图 &#xff0c;里面图片自行替换 效果图1完整代码案例如下&#xff1a; import { authentication } …

福特汽车物流仓储系统WMS:开源了,可直接下载

导语 大家好&#xff0c;我是社长&#xff0c;老K。专注分享智能制造和智能仓储物流等内容。欢迎大家到本文底部评论区留言。 近日&#xff0c;福特汽车公司推出了其广受好评的仓库管理系统GreaterWMS&#xff08;更大仓库管理系统&#xff09;的开源版本&#xff0c;意味着各行…

STM32完全学习——FLASH上FATFS文件管理系统

一、需要移植的接口 我们通过看官网的手册&#xff0c;可以看到我们只要完成下面函数的实现&#xff0c;就可以完成移植。我们这里只移植前5个函数&#xff0c;获取时间的函数我们不在这里移植。 二、移植接口函数 DSTATUS disk_status (BYTE pdrv /* Physical drive nmuber…

pyqt5冻结+分页表

逻辑代码 # -*- coding: utf-8 -*- import sys,time,copy from PyQt5.QtWidgets import QWidget,QApplication, QDesktopWidget,QTableWidgetItem from QhTableWidgetQGN import Ui_QhTableWidgetQGN from PyQt5.QtCore import Qt from PyQt5 import QtCore, QtGui, QtWidgets…

Windows 使用 非安装版MySQL 8

1.下载MySQL 8 https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.40-winx64.zip 2.创建my.ini 下载解压后&#xff0c;发现根目录没有my.ini文件&#xff0c;需手动创建 my.ini # For advice on how to change settings please see # http://dev.mysql.com/doc/refma…

海外招聘丨 苏黎世联邦理工学院—机器学习在社会和政治科学中的应用博士后

雇主简介 苏黎世联邦理工学院是世界领先的科技大学之一。我们以优质的教育、尖端的基础研究和将新知识直接转化为社会而闻名。来自 120 多个国家的 30,000 多名学生认为我们的大学是一个鼓励独立思考和激励卓越的环境的地方。 我们位于欧洲中心&#xff0c;但与世界各地建立联…

微信小程序中遇到过的问题

记录微信小程序中遇到的问题&#xff08;持续更新ing&#xff09; 问题描述&#xff1a;1. WXML中无法直接调用JavaScript方法。2. css中无法直接引用背景图片。3. 关于右上角胶囊按钮。4. 数据绑定问题。5. 事件处理问题。 问题描述&#xff1a; 1. WXML中无法直接调用JavaSc…

idea 8年使用整理

文章目录 前言idea 8年使用整理1. 覆盖application配置2. 启动的时候设置编辑空间大小&#xff0c;并忽略最大空间3. 查询类的关系4. 查看这个方法的引用关系5. 查看方法的调用关系5.1. 查看被调用关系5.2. 查看调用关系 6. 方法分隔线7. 选择快捷键类型8. 代码预览插件9. JReb…

RAGFLOW使用笔记【更新ing】

0.引言 本文记录使用RAGFLOW的一些问题以及解决办法&#xff0c;它以笔记的形式存在&#xff0c;方便我以后回顾自己的学习工作。 1.RAGFLOW上传文件大小默认是128M,如何修改上传文件大小&#xff1f; 更新ragflow/docker/.env中的MAX_CONTENT_LENGTH 环境变量 然后同步更新…

ubuntu22.04安装PaddleX3

PaddleOCR 安装过程可以参考PaddleX本地安装教程 我的电脑环境配置&#xff1a; ubuntu22.04 cuda11.8&#xff08;之前安装的是12.4没有匹配的paddle-gpu;这里改成11.8&#xff09; 一、安装基础环境 1、 conda create -n ppx1 python3.10 2、 conda activate ppx1 3、…

Android 之 Activity 的启动模式(launchMode)

一、Activity 启动模式 在实际项目中&#xff0c;应该根据项目的实际需要来为每个 Activity 指定恰当的启动模式 launchMode。启动模式一共有四种&#xff0c;分别是 standard、singleTop、singleTask 和 singleInstance。可以在 AndroidManifest.xml 中通过给 <activity&g…