MySQL——表的约束

表约束

一、概念

​ 表中一定要有各种约束,通过各种约束使得未来插入到数据库中的数据是合法的,在语法上是没有问题的;

​ 约束本质就是通过技术手段,倒逼着程序员插入正确的数据,换句话说就是,插入进来的数据一定是符合数据约束的;最终保证数据的完整性和可预期性;

二、非空约束

select null;#NULL表示没有,不区分大小写;

在这里插入图片描述

select 1+null;#实际上null是不会参与计算的

在这里插入图片描述

​ 空属性有两个值,分别是null(默认值)和not null;创建表时除了写表属性和类型之外还可以添加null和not null分别表示允许为空和不允许为空;

在这里插入图片描述

​ Null列表示是否启用空属性约束;默认约束是Null,由于不启用空约束所以就不允许插入缺省值了;

三、默认约束

​ 常用的某一个具体值,可以一开始就指定好,用户需要显式传递时允许用户传入其需求值;

​ default和not NULL并不冲突,当用户显示插入对应属性时,可以插入NULL或者合法数据,当不插入数据时,如果设置了default就会自动插入缺省值,没设置就必须用户显示插入;

​ MySQL默认的default值是NULL;

四、comment约束

​ 相当于属性字段的注释,用于程序员和DBA进行了解;

create table 表名(属性名 属性类型 非空约束 默认约束 comment '属性注释');

五、zerofill约束

create table 表名(属性名 属性类型 非空约束 默认约束 comment '属性注释'zerofill);
#zerofill表示是否启用;

​ 关于显示方面的约束;如果显示的宽度小于指定的宽度,使用zerofill填充之后就会使用0填充指定的宽度;如果数据的宽度大于zerofill约束指定宽度,还是可以正常显示,所以zerofill是一种至少的行为;

​ int是4个字节,无符号显示出来就是十个位,有符号还有符号位所以是十一位;

六、主键约束

​ 主键:primary key用来唯一约束该字段里面的数据,不能重复,不能为空,一张表里面只能有一个主键;

create table 表名(属性名 属性类型 非空约束 默认约束 zerofill primary key comment '属性注释');
create table 表名(属性名 属性类型 非空约束 默认约束 zerofill comment '属性注释',primary key('属性名'));

​ 存在的意义就是:使得属性唯一标识,不可以被修改,便于增删查改;

alter table 表名 add primary key(属性字段);
alter table 表名 drop primary key;

​ 主键也可以添加到多列,即复合主键,仍然是一个主键;

​ 严格的按照一对一的关系,不允许同一个记录重复出现;

6.1自增长约束

​ auto_increment是主键的一种,插入数据时可以不用考虑它,每次在插入数据时都会自动地进行最大数据加一;**自增长约束一般都必须设置成主键;自增长字段必须是整数;一张表只能有一个自增长;**常用于索引;

create table if not exists t2(id int unsigned primary key auto_increment,name varchar(20) not null
)auto_increment=5;Create Table: CREATE TABLE `t2` (`id` int(10) unsigned NOT NULL AUTO_INCREMENT,`name` varchar(20) NOT NULL,PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8
#除了表内属性进行了优化,表外属性也自动添加AUTO_INCREMENT=5,表明下一次插入时会使用的主键值;每次插入玩=完成之后会更新AUTO_INCREMENT字段;

​ 补充:索引的本质就是以空间换时间,为kv映射关系提供了专门的空间,便于快速定位;索引和主键相关

七、唯一键约束

create table t3(id char(20) unique comment '这是一个学生的唯一键学号',name varchar(32) not null
);Create Table: CREATE TABLE `t3` (`id` char(20) DEFAULT NULL COMMENT '这是一个学生的唯一键学号',`name` varchar(32) NOT NULL,UNIQUE KEY `id` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | char(20)    | YES  | UNI | NULL    |       |
| name  | varchar(32) | NO   |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+

​ 唯一键与逐渐最大的不同就是可以为空,并且空可以重复;

​ 他们之间互为补充,其中选择了主键作为索引,但是其他的属性逻辑上也要保证唯一性,所以需要有唯一键来保证唯一性;

八、外键约束

​ 外键常用于主表和从表之间建立联系;即从表中有属性与主表的主键或者唯一键属性相关联,此时就需要使用外键建立联系;

create table if not exists student(id int primary key,name varchar(20) not null,telephone varchar(20) unique key,class_id int,foreign key(class_id) references class(id)
);Create Table: CREATE TABLE `student` (`id` int(11) NOT NULL,`name` varchar(20) NOT NULL,`telephone` varchar(20) DEFAULT NULL,`class_id` int(10) unsigned DEFAULT NULL,PRIMARY KEY (`id`),UNIQUE KEY `telephone` (`telephone`),KEY `class_id` (`class_id`),CONSTRAINT `student_ibfk_1` FOREIGN KEY (`class_id`) REFERENCES `class` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8+-----------+------------------+------+-----+---------+-------+
| Field     | Type             | Null | Key | Default | Extra |
+-----------+------------------+------+-----+---------+-------+
| id        | int(11)          | NO   | PRI | NULL    |       |
| name      | varchar(20)      | NO   |     | NULL    |       |
| telephone | varchar(20)      | YES  | UNI | NULL    |       |
| class_id  | int(10) unsigned | YES  | MUL | NULL    |       |
+-----------+------------------+------+-----+---------+-------+

​ 外键既可以保证从表插入时,需要符合约束条件,也可以保证从表外键约束有数据时不可以删除主表内容;

​ 定义外键时必须保证外键列数据在主表中存在或者为空;

九、综合案例

​ 约束会保证凡是进入mysql中的数据一定是符合规定的;

一个商店的数据记录客户端及客户购物情况,由三个表组成;

​ 商品goods(商品编号goods_id,商品名goods——name,单价unitprice,商品类别category,供应商provider);

​ 客户customer(客户号customer_id,姓名name,住址address,邮箱email,性别sex,身份证card_id);

​ 购买purchase(购买订单号order_id,客户号customer_id,商品号goods_id,购买数量nums);

要求:

​ 每个表的主外键;

​ 客户的姓名不能为空值;

​ 邮箱不能重复;

​ 客户的性别(男,女);

-- 创建数据库
create database if not exists bit32mall
default character set utf8 ;
-- 选择数据库
use bit32mall;
-- 创建数据库表
-- 商品
create table if not exists goods
(goods_id int primary key auto_increment comment '商品编号',goods_name varchar(32) not null comment '商品名称',unitprice int not null default 0 comment '单价,单位分',category varchar(12) comment '商品分类',provider varchar(64) not null comment '供应商名称'
);
-- 客户
create table if not exists customer
(customer_id int primary key auto_increment comment '客户编号',name varchar(32) not null comment '客户姓名',address varchar(256) comment '客户地址',email varchar(64) unique key comment '电子邮箱',sex enum('男','女') not null comment '性别',card_id char(18) unique key comment '身份证'
);
-- 购买
create table if not exists purchase
(order_id int primary key auto_increment comment '订单号',customer_id int comment '客户编号',goods_id int comment '商品编号',nums int default 0 comment '购买数量',foreign key (customer_id) references customer(customer_id),foreign key (goods_id) references goods(goods_id)
);

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

6个精品免费wordpress模板下载

要找到视觉效果非常出色的WordPress模板,我们可以从多个角度来考虑。根据《Smashing WordPress Themes: Making WordPress Beautiful》一书,WordPress不仅仅是一个博客平台,它还能被用来创建各种风格的网站,从企业网站到摄影画廊等…

洗地机哪个牌子好?全面评测多款口碑洗地机

洗地机的出现,让人们摆脱了每天打扫卫生的繁琐,因为它只需轻轻一推,就能把扫地、拖地、擦地的活全做了,干垃圾湿垃圾统统都能一次清理干净,操作简单,更轻松。本文主要分享一些挑选洗地机的技巧,…

大数据运维学习笔记之Ambari——筑梦之路

原则:分布式存储和分布式计算分开 今天就到这里啦。

【HarmonyOS4学习笔记】《HarmonyOS4+NEXT星河版入门到企业级实战教程》课程学习笔记(十)

课程地址: 黑马程序员HarmonyOS4NEXT星河版入门到企业级实战教程,一套精通鸿蒙应用开发 (本篇笔记对应课程第 17 节) P17《16.Ark-状态管理Prop Link Provide Consume》 将上一节写出的代码进行功能模块封装:1、任务…

一个通过ADC采集NTC热敏电阻的温度传感器

前言: 如何设计一个电路,使用具有逐次逼近寄存器(SAR)模数转换器(ADC)的热敏电阻直接监测温度呢?温度传感电路需要使用负温度系数(NTC)热敏电阻与电阻器串联形成分压器,监测-25C至100C的温度范围。分压器具有产生与监测的温度成反比的输出电压的效果。电阻器分压器的…

如何彻底搞懂迭代器(Iterator)设计模式?

说起迭代器(Iterator),相信你并不会陌生,因为我们几乎每天都在使用JDK中自带的各种迭代器。那么,这些迭代器是如何构建出来的呢?就需要用到了今天内容要介绍的迭代器设计模式。在日常开发过程中&#xff0c…

查找效率满分的算法—— “二分查找” 算法 (Java版)

本篇会加入个人的所谓鱼式疯言 ❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言 而是理解过并总结出来通俗易懂的大白话, 小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的. 🤭🤭🤭可能说的不是那么严谨.但小编初心是能让更多人…

深入了解Nginx(一):Nginx核心原理

一、Nginx核心原理 本节为大家介绍Nginx的核心原理,包含Reactor模型、Nginx的模块化设计、Nginx的请求处理阶段. (本文源自微博客,且已获得授权) 1.1、Reactor模型 Nginx对高并发IO的处理使用了Reactor事件驱动模型。Reactor模型的基本组件包含时间收集…

使用xsd验证xml格式的正确性

1.1 基础知识介绍 XML简介:XML是可扩展标记语言(eXtensible Markup Language)的缩写,它是一种数据表示格式,可以描述非常复杂的数据结构,常用于传输和存储数据。xml文件、xml消息。XSD简介:是X…

LabVIEW和ZigBee无线温湿度监测

LabVIEW和ZigBee无线温湿度监测 随着物联网技术的迅速发展,温湿度数据的远程无线监测在农业大棚、仓库和其他需环境控制的场所变得日益重要。开发了一种基于LabVIEW和ZigBee技术的多区域无线温湿度监测系统。系统通过DHT11传感器收集温湿度数据,利用Zig…

uniapp-自定义navigationBar

封装导航栏自定义组件 创建 nav-bar.vue <script setup>import {onReady} from dcloudio/uni-appimport {ref} from vue;const propsdefineProps([navBackgroundColor])const statusBarHeight ref()const navHeight ref()onReady(() > {uni.getSystemInfo({success…

图生代码,从Hello Onion 代码开始

从Hello Onion 代码开始 1&#xff0c;从代码开始 原生语言采用java 作为载体。通过注解方式实现“UI可视化元素"与代码bean之间的映射. 转换示例 2&#xff0c;运行解析原理 在执行JAVA代码期间&#xff0c;通过读取注解信息&#xff0c;转换为前端的JSON交由前端JS框…

c++设计模式-->访问者模式

#include <iostream> #include <string> #include <memory> using namespace std;class AbstractMember; // 前向声明// 行为基类 class AbstractAction { public:virtual void maleDoing(AbstractMember* member) 0;virtual void femaleDoing(AbstractMemb…

安装Pnetcdf顺便升级autoconf与automake

Netcdf NetCDF&#xff08;Network Common Data Form&#xff09;是一种用于存储科学数据的文件格式和软件库。它是一种自描述、可移植且可扩展的数据格式&#xff0c;广泛应用于气象学、海洋学、地球科学和其他领域的科学研究。 NetCDF文件以二进制形式存储&#xff0c;结构…

Qt | QGridLayout 类(网格布局)

01、上节回顾 Qt | QBoxLayout 及其子类(盒式布局)02、QGridLayout 简介 1、网格布局原理(见下图): 基本原理是把窗口划分为若干个单元格,每个子部件被放置于一个或多个单元格之中,各 单元格的大小可由拉伸因子和一行或列中单元格的数量来确定,若子部件的大小(由 sizeH…

Vue从入门到实战 Day08~Day10

智慧商城项目 1. 项目演示 目标&#xff1a;查看项目效果&#xff0c;明确功能模块 -> 完整的电商购物流程 2. 项目收获 目标&#xff1a;明确做完本项目&#xff0c;能够收获哪些内容 3. 创建项目 目标&#xff1a;基于VueCli自定义创建项目架子 4. 调整初始化目录 目…

网络安全之BGP详解

BGP&#xff1b;边界网关协议 使用范围&#xff1b;BGP范围&#xff0c;在AS之间使用的协议。 协议的特点&#xff08;算法&#xff09;&#xff1a;路径矢量型&#xff0c;没有算法。 协议是否传递网络掩码&#xff1a;传递网络掩码&#xff0c;支持VLSM&#xff0c;CIDR …

ASP+ACCESS基于B2C电子商务网站设计

摘 要 运用ASP技术结合了Access数据库原理&#xff0c;基于B/S模式我们开发了一个网上购物系统。在我们的系统中&#xff0c;顾客可以很方便的注册成为会员&#xff0c;对商品进行浏览检索&#xff0c;查看商品的详细资料&#xff0c;然后根据各人的喜好购买心仪的商品。系统…

CCF20220901——如此编码

CCF20220901——如此编码 代码如下&#xff1a; #include<bits/stdc.h> using namespace std; int main() {int n,m,cnt1,a[1000],c[1000]{1};cin>>n>>m;for(int i1;i<n;i){cin>>a[i];cnt*a[i];c[i]cnt;}int b[1000]{0};for(int i1;i<n;i)b[i](…

JPHS-JMIR Public Health and Surveillance

文章目录 一、期刊简介二、征稿信息三、期刊表现四、投稿须知五、投稿咨询 一、期刊简介 JMIR Public Health and Surveillance是一本多学科期刊&#xff0c;专注于公共卫生创新与技术的交叉领域&#xff0c;包括公共卫生信息学、监测&#xff08;监测系统和快速报告&#xff…