MySql 约束

目录

约束介绍

主键 Primary key

not null 非空  和unique 唯一 

foreign key 外键

 check

约束练习


约束介绍

基本介绍

        约束用于确保数据库的数据满足特定的商业规则。在mysql中,约束包括: not null、unique,primary key, foreign key,和check五种

主键 Primary key

1.用于定义唯一的标标示表行的数据,当主键约束后该列不能重复。

2.标示主键的列不能为空。

3,一个表中只能有一个主键,但可以是复合主键

4.主键1的指定方式有两种 直接在字段后指定 primary key,或在表定义最后写primary key(列名,列名,....)

5.在实际开发中,每个表往往都会设计一个主键。

-- 演示添加复合主键(id,和 name 做成复合主键)
CREATE TABLE t01
	(`id` int,
	`name` VARCHAR(10),
	`email` VARCHAR(20),
	PRIMARY KEY (id , `name`))-- 这里就是复合主键

复合主键的作用是,当往t01 表里添加 id 和name 时, 两个数值不能同时和表中的一条数据相同。

not null 非空  和unique 唯一 

-- unqiue使用细节,和主键相似,但主键不能为空。

 --如果没有指定not null ,则unique字段可以有多个nu1

--一张表可以有多个unique字段

foreign key 外键

 

         如上图,jack和班级表的id=200发生了外键连接,那么直接删除id = 200的那条记录是会失败的,只有先把jack然后再删除 id= 200 才行。

-- 	外键
CREATE TABLE my_class(
			id INT PRIMARY KEY ,
			`name` VARCHAR(10) not NULL DEFAULT '');
			
CREATE TABLE my_stu(
			id INT PRIMARY KEY,
			`name` VARCHAR(10) not NULL DEFAULT '',
			class_id INT,
			FOREIGN KEY (class_id) REFERENCES my_class(id)) -- 设置外键

-- 测试数据
INSERT INTO my_class
		VALUES(100,'java'),(200,'web')
INSERT INTO my_stu
		VALUES(1,'tom',100)-- 加入成功
INSERT INTO my_stu
		VALUES(2,'som',200)-- 加入成功		
INSERT INTO my_stu
		VALUES(3,'rose',300)-- 加入失败	
	
	DELETE FROM my_class
	WHERE id = 100 -- 删除失败
		DELETE FROM my_class
	WHERE id = 200 -- 删除失败

 如果外键设置了没效果是因为数据库引擎的问题,应把在创建表时指定引擎为InnoDB

 

 check

CREATE table ee
( `id` INT,
	sex VARCHAR(4) CHECK (sex IN('man','woman')),
	sal int CHECK (sal BETWEEN 1000 AND 2000))
	ENGINE INNODB

INSERT INTO ee
VALUES (1,'man',1500)
INSERT INTO ee
VALUES (1,'xx',1500) -- 按道理这条语句不生效,可是用的是5,7版本只做语法的校验,check并不生效
	

约束练习

CREATE TABLE goods (
				goods_id INT PRIMARY KEY auto_increment,
				unitprice INT CHECK (sal BETWEEN 1 and 9999),
				category VARCHAR(10),
				provider VARCHAR(10))
				ENGINE INNODB;

CREATE TABLE customer(
					customer_id INT PRIMARY KEY auto_increment,
					`name` VARCHAR(10) NOT null,
					address VARCHAR(20),
					email VARCHAR(20) UNIQUE,
					sex ENUM('男','女') NOT NULL,
					card_id int)
					CHARACTER SET utf8 COLLATE utf8_bin ENGINE INNODB
					
CREATE TABLE purchase (
					order_id INT PRIMARY KEY auto_increment,
					customer_id INT,
					goods_id INT,
					nums INT,
		FOREIGN KEY (customer_id) REFERENCES customer(customer_id),
		FOREIGN KEY (goods_id) REFERENCES goods(goods_id))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值