标签:删除 auto name 主键约束 插入 建表 有一个 默认值 ble
保证用户输入的数据保存到数据库中是正确的
在创建表的时候给表添加约束
实体完整性、域完整性、引用完整性
?
?
表中的一行(一条记录)代表一个实体 (entity)
实体完整性的作用:标记每一行数据不重复。行级约束
约束类型:
主键约束(primary key):
每个表中要有一个主键,数据唯一,且不能为null
创建主键的方式:
create table pe(ID BIGINT PRIMARY key, name VARCHAR(50));
create table pe2(ID BIGINT, name VARCHAR(50), PRIMARY KEY(ID));
联合主键:两个字段数据同时相同时,才违反联合主键约束。 create table stu2(ID BIGINT,snum BIGINT, name VARCHAR(50), PRIMARY KEY(ID, snum));
更改表结构,设置主键:ALTER TABLE student ADD CONSTRAINT PRIMARY KEY(sid);
唯一约束 :
CREATE TABLE table1(id int PRIMARY KEY, name VARCHAR(50) UNIQUE);
name不能重复自动增长列
指定列的数据自动增长,即使数据删除,依然继续增长
CREATE TABLE table1(
id int PRIMARY KEY auto_increment,
name varchar (20) UNIQUE
);
?
使用:限制此单元格的数据正确,不对照此列的其他单元格比较
域,代表当前单元格
域完整性约束:
数据类型:数值、日期、字符串
非空约束(not null) CREATE TABLE table1(id int PRIMARY KEY auto_increment,name varchar (20) UNIQUE not null);
-- 默认值约束 (default)
CREATE TABLE table1(id int PRIMARY KEY auto_increment,name varchar (20) UNIQUE not null,sex char(1) default '男')
-- 设置默认值为 男
?
?
?
什么是参照完整性
数据库的主键和外键类型要一致
两个表必须是 InnoDB 类型
设置参照完整性后,外键当中的内值,必须得是主键当中的内容
-- 设置外键
CREATE TABLE score(
sid int PRIMARY KEY score int,
CONSTRAINT sc_st_fk FOREIGN KEY(sid) REFERENCES stu(id)
);
-- score 设置外键,score 里的sid 关联 stu 里的 id
-- 设置外键
alter table score add CONSTRAINT sc_st_fk FOREIGN KEY(sid) REFERENCES stu(id);
-- 多对多关系创建
CREATE TABLE teach(tid int PRIMARY KEY, name VARCHAR(50));
CREATE TABLE stu(sid int PRIMARY KEY, name VARCHAR(50));
CREATE TABLE tea_stu_rel(tid int, sid int);
ALTER TABLE tea_stu_rel ADD CONSTRAINT FOREIGN KEY(tid) REFERENCES teach(tid);
ALTER TABLE tea_stu_rel ADD CONSTRAINT FOREIGN KEY(sid) REFERENCES stu(sid);
为什么要将表拆分:避免冗余数据
标签:删除 auto name 主键约束 插入 建表 有一个 默认值 ble
原文地址:https://www.cnblogs.com/friday69/p/9390961.html