主键
primary key
用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表最多只能有一个主键,主键所在的列通常是整数类型
mysql> create table student(
-> id int primary key comment '学生id,唯一且非空',
-> name varchar(6)
-> );
mysql> desc student;
+-------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | | <= key中显示PRI
| name | varchar(6) | YES | | NULL | |
+-------+------------+------+-----+---------+-------+
mysql> insert into student values (1,'张三');
Query OK, 1 row affected (0.00 sec)
mysql> insert into student values (1,'李四');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
alter table 表名 add primary key(属性名);
alter table 表名 drop primary key;
mysql> create table student(
-> id int,
-> name varchar(6),
-> primary key(id,name) //id和name的复合主键
-> );
mysql> desc student;
+-------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | |
| name | varchar(6) | NO | PRI | NULL | |
+-------+------------+------+-----+---------+-------+
如此,id和name都不允许为空,且不能重复(两个都相同才算重复)
auto_increment
:当对应的字段不显示赋值时,系统会赋值为当前字段中已经有的最大值+1。通常和主键搭配使用
自增长的特点:
mysql> create table student(
-> id int unsigned primary key auto_increment,
-> name varchar(6)
-> );
mysql> show create table student \G;
*************************** 1. row ***************************
Table: student
Create Table: CREATE TABLE `student` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(6) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
mysql> insert into student (name) values ('张三');
mysql> insert into student (name) values ('李四');
mysql> insert into student (name) values ('王五');
mysql> select * from student;
+----+--------+
| id | name |
+----+--------+
| 1 | 张三 |
| 2 | 李四 |
| 3 | 王五 |
+----+--------+
mysql> show create table student \G;
*************************** 1. row ***************************
Table: student
Create Table: CREATE TABLE `student` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(6) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8
创建表时,如果没有指定自增长的起始值,默认为1
每次插入数据后,MySQL会保存当前自增长属性的最大值+1,供下次插入使用
如果此时插入一个id=500的,那么MySQL保存的就是501
mysql> insert into student (id,name) values (500,'赵六');
mysql> show create table student \G;
*************************** 1. row ***************************
Table: student
Create Table: CREATE TABLE `student` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(6) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=501 DEFAULT CHARSET=utf8
mysql> create table student(
-> id int unsigned primary key auto_increment,
-> name varchar(6)
-> )auto_increment=500; //指定自增长的起始值
一张表往往有很多字段需要唯一性,数据不能重复,但是一张表只能有一个主键;唯一键就可以解决表中多个字段需要唯一性约束的问题
唯一键和主键本质差不多,唯一键允许为空,而且可以多个为空,空字段不作唯一性比较
应用场景:
员工号和身份证。员工号作主键不允许为空且唯一,但身份证同样不允许重复,但又不能和员工号组成复合主键,所以可以使用唯一键
mysql> create table worker(
-> id int unsigned primary key auto_increment comment '员工工号',
-> telephone int unique comment '员工电话号',
-> name varchar(6) comment '员工姓名'
-> );
mysql> insert into worker (telephone,name) values (123456,'张三');
mysql> insert into worker (telephone,name) values (123456,'李四');
ERROR 1062 (23000): Duplicate entry '123456' for key 'telephone'
mysql> insert into worker (telephone,name) values (NULL,'李四');
mysql> insert into worker (telephone,name) values (NULL,'王五');
mysql> select * from worker;
+----+-----------+--------+
| id | telephone | name |
+----+-----------+--------+
| 1 | 123456 | 张三 |
| 3 | NULL | 李四 |
| 4 | NULL | 王五 |
+----+-----------+--------+
外键用于定义主表和从表之间的关系;外键约束主要定义在从表上,主表则必须有主键约束或唯一键约束。当定义外键后,要求外键列数据必须在主表中存在或为NULL
foreign key(字段名) references 主表(字段名)
如此,课程表为主表,学生表为从表
mysql> create table course(
-> id int unsigned primary key,
-> name varchar(6)
-> );
mysql> create table student(
->id int unsigned primary key,
->name varchar(6),
->class_id int unsigned,
->foreign key (class_id) references coursse(id)
->);
注意点:
mysql> insert into course values (001,'高数课');
Query OK, 1 row affected (0.00 sec)
mysql> insert into student values (100,'张三',001);
Query OK, 1 row affected (0.00 sec)
//不允许在从表的外键中插入不存在于主表的数据
mysql> insert into student values (200,'李四',002);
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint
fails (`test_demo`.`student`, CONSTRAINT `student_ibfk_1` FOREIGN KEY (`class_id`)
REFERENCES `course` (`id`))
//主表对应外键,在从表中有数据时,不允许删除该外键
mysql> delete from table course where id=001;
ERROR 1064 (42000): You have an error in your SQL syntax;
check the manual that corresponds to your MySQL server version for the right syntax to use
near 'table course where id=001' at line 1
感谢你的阅读
如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。