MYSQL一一约束

概述:

①概念约束是作用于表中字段的规则,用于限制存储在表中的数据

②目的:保证数据库中的数据的正确性,有效性和完整性

③分类:

MYSQL一一约束_第1张图片

注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束

约束演示:

MYSQL一一约束_第2张图片

创建表格

CREATE TABLE yueshu(
    id INT
PRIMARY KEY AUTO_INCREMENT COMMENT '主键',        //主键 //自动增长
    NAME VARCHAR(10) NOT NULL UNIQUE COMMENT '姓名',        //不为空 //唯一
    age INT CHECK(age > 0 && age <= 120) COMMENT '年龄',        //字段age为0~120
    STATUS CHAR(1) DEFAULT '1' COMMENT '状态',                        //默认值为1
    gender CHAR(1) COMMENT '性别'
);

MYSQL一一约束_第3张图片

①检测id字段是否为主键且自动增长

INSERT INTO yueshu (NAME,age,STATUS,gender) VALUES ('tom',19,'1','男');
INSERT INTO yueshu (NAME,age,STATUS,gender) VALUES ('tom2',19,'1','男');

MYSQL一一约束_第4张图片

②检测name字段是否唯一且不为空

INSERT INTO yueshu (NAME,age,STATUS,gender) VALUES (NULL,19,'1','男');

INSERT INTO yueshu (NAME,age,STATUS,gender) VALUES ('tom2',19,'1','男');
 

MYSQL一一约束_第5张图片

MYSQL一一约束_第6张图片

③检测年龄字段是否为0~120之间

INSERT INTO yueshu (NAME,age,STATUS,gender) VALUES ('tom3',121,'1','男');

MYSQL一一约束_第7张图片

④检测状态字段是否不输入值为默认值

INSERT INTO yueshu (NAME,age,gender) VALUES ('tom4',121,'男');
 

你可能感兴趣的:(mysql,数据库)