由于增删改了emp表中的记录,因此这里重新创建了一个脚本并使用 create database bjpowernnode;
use bjpowernode;
source C:\Users\Administrator\Desktop\bjpowernode.sql; 登录后复制 约束1.什么是约束? 约束就是表中的限制条件 约束的关键字是:constraint
2. 约束的分类 1. not null(非空约束)not null约束的字段,不能为null值,必须给具体的数据 创建表,给字段添加 非空约束【用户的邮箱地址不能为空】 drop table if exists t_user;
create table t_user(
id int(10),
name varchar(32) not null,
email varchar (32)
); 登录后复制 

2. unique(唯一性约束)创建表,保证邮箱地址唯一 create table t_user(
id int(10),
name varchar(32) not null,
email varchar(128) unique
); 登录后复制 
unique约束的字段不能重复,但是可以为null 
以上的约束属于列级约束 表级约束: create table t_user(
id int(10),
name varchar(32),
email varchar(128),
unique(email)
); 登录后复制 1.使用表级约束给多个字段添加约束 create table t_user(
id int(10),
name varchar(32),
email varchar(128),
unique(name,email)
); 登录后复制 2.表级约束可以给约束起名,以后通过这个名字来删除约束 create table t_user(
id int(10),
name varchar(32),
email varchar(128),
constraint t_user_email_unique unique(email)
); 登录后复制 


not null 和unique可以联合使用 
3. primary key (主键约束)1.主键涉及到的术语: 2.以上三者之间的关系: 3.给某个字段添加主键约束以后,该字段不能重复,也不能为空 4. 一张表应给有主键字段,如果没有,表示这张表是无效的 主键值是当前行数据的唯一标识 主键值是当前行数据的身份证号码 即使表中的两行记录数据是完全相同的, 但是由于主键值不同,就认为这是两行完全不同的字段
5.无论是单一主键还是复合主键,一张表的主键约束只能有一个 给一个字段添加主键约束,被称为单一主键约束 给多个字段联合添加主键约束,被称为复合主键
6.主键根据性质分类: 单一主键,列级约束 create table t_user(
id int(10) primary key,
name varchar(32)
); 登录后复制 
单一主键,表极约束 create table t_user(
id int(10),
name varchar(32),
primary key(id)
); 登录后复制 
复合主键:只能用表级约束 mysql> create table t_user(
-> id int(10),
-> name varchar(32),
-> primary key(id,name)
-> ); 登录后复制 

auto_increment:主键自增 MySQL数据管理系统中提供了一个自增的数字,专门用来自动生成主键值 主键值不需要用户维护,也不需要用户提供了,自动生成的, 这个自增的数字默认从1开始以1递增:1,2,3,4,.... mysql> create table t_user(
-> id int(10) primary key auto_increment,
-> name varchar(32)
-> ); 登录后复制 
4. foreign key(外键约束)1.外键约束涉及到的术语: 2.以上三者之间的关系: 某个字段添加外键约束以后称为外键字段 外键字段中的每一个数据称为外键值
3.外键分为单一外键和复合外键 单一外键:给一个字段添加外键约束 复合外键:给多个字段添加外键约束
4.一张表中可以有多个外键字段 设计一个数据库表,用来存储学生和班级信息,给出两种解决方案: 学生信息和班级信息之间的关系:一个班级对应多个学生,这是典型的一对多的关系 在多的一方加外键 第一种设计方案:将学生信息和班级信息存储到一张表中 第二种设计方案:将学生信息和班级信息分开两张表存储,学生表+班级表 sno(主键约束) | sname | classno(外键约束) |
---|
1 | jack | 100 | 2 | lucy | 100 | 3 | kk | 100 | 4 | smith | 200 | 5 | frank | 300 | 6 | jhh | 300 |
cno(主键约束) | cname |
---|
100 | 高三1班 | 200 | 高三2班 | 300 | 高三3班 |
为了保证t_student 表中的classno字段中的数据必须来自于t_class表中的cno字段中的数据,有必要给t_student表中的classno字段添加外键约束,classno称为外键字段,该字段中的值称为外键值。 注意: 1.外键值可以为空 2.外键字段必须得引用这张表中的主键吗? 3.班级表为父表,学生表为子表 
DROP TABLE IF EXISTS t_student;
DROP TABLE IF EXISTS t_class;
CREATE TABLE t_class(
cno INT(3) PRIMARY KEY,
cname VARCHAR(128) NOT NULL UNIQUE
);
CREATE TABLE t_student(
sno INT(3) PRIMARY KEY,
sname VARCHAR(32) NOT NULL,
classno INT(3),-- 外键
CONSTRAINT t_student_class_fk FOREIGN KEY(classno) REFERENCES t_class(cno)
);
INSERT INTO t_class(cno,cname) VALUES(100,'高三1班');
INSERT INTO t_class(cno,cname) VALUES(200,'高三2班');
INSERT INTO t_class(cno,cname) VALUES(300,'高三3班');
INSERT INTO t_student(sno,sname,classno) VALUES(1,'jack',100);
INSERT INTO t_student(sno,sname,classno) VALUES(2,'lucy',100);
INSERT INTO t_student(sno,sname,classno) VALUES(3,'hh',100);
INSERT INTO t_student(sno,sname,classno) VALUES(4,'frank',200);
INSERT INTO t_student(sno,sname,classno) VALUES(5,'smith',300);
INSERT INTO t_student(sno,sname,classno) VALUES(6,'jhh',300);
SELECT * FROM t_student;
SELECT * FROM t_class;
-- 添加失败,因为有外键约束
INSERT INTO t_student(sno,sname,classno) VALUES(8,'kk',500); 登录后复制 重点:典型的一对多关系,设计时在多的一方加外键 5. 级联更新与级联删除在删除父表中的数据的时候,级联删除子表中的数据 在更新父表中的数据的时候,级联更新子表中的数据 以上的级联更新和级联删除谨慎使用, 因为级联操作会使数据数据改变或删除,数据是无价的。 语法: 级联更新:on update cascase 级联删除:on delete cascase


MySQL中对于有些约束的修改比较麻烦,所以应该先删除约束,再添加约束 删除外键约束: alter table t_student drop foreign key t_student_class_fk 登录后复制 添加外键约束并级联更新: alter table t_student add constraint t_student_class_fk foreign key(classno)
references t_class(no) on delete cascade; 登录后复制 添加外键约束并级联删除: alter table t_student add constraint t_student_class_fk foreign key(classno)
references t_class(no) on update cascade; 登录后复制 级联删除 

级联更新 

以上就是MySQL创建表时的条件有哪些的详细内容,更多请关注模板之家(www.mb5.com.cn)其它相关文章! |