mysql中可以通过“alter table 表名 add primary key(字段名);”语句在修改数据表时添加主键约束;当在修改表时要设置表中某个字段的主键约束时,要确保设置成主键约束的字段中值不能够有重复的,并且要保证是非空的。
(推荐教程:mysql视频教程)
主键(primary key)的完整称呼是“主键约束”,是 mysql 中使用最为频繁的约束。一般情况下,为了便于 dbms 更快的查找到表中的记录,都会在表中设置一个主键。
在创建表时设置主键约束
在 create table 语句中,通过 primary key 关键字来指定主键。
在定义字段的同时指定主键,语法格式如下:
<字段名> <数据类型> primary key [默认值]
示例
在 test_db 数据库中创建 tb_emp3 数据表,其主键为 id,sql 语句和运行结果如下。
mysql> create table tb_emp3 -> ( -> id int(11) primary key, -> name varchar(25), -> deptid int(11), -> salary float -> );query ok, 0 rows affected (0.37 sec)mysql> desc tb_emp3;+--------+-------------+------+-----+---------+-------+| field | type | null | key | default | extra |+--------+-------------+------+-----+---------+-------+| id | int(11) | no | pri | null | || name | varchar(25) | yes | | null | || deptid | int(11) | yes | | null | || salary | float | yes | | null | |+--------+-------------+------+-----+---------+-------+4 rows in set (0.14 sec)
在修改表时添加主键约束
主键约束不仅可以在创建表的同时创建,也可以在修改表时添加。但是需要注意的是,设置成主键约束的字段中不允许有空值。
在修改数据表时添加主键约束的语法格式如下:
alter table <数据表名> add primary key(<字段名>);
通常情况下,当在修改表时要设置表中某个字段的主键约束时,要确保设置成主键约束的字段中值不能够有重复的,并且要保证是非空的。否则,无法设置主键约束。
示例
查看 tb_emp2 数据表的表结构,sql 语句和运行结果如下所示。
mysql> desc tb_emp2;+--------+-------------+------+-----+---------+-------+| field | type | null | key | default | extra |+--------+-------------+------+-----+---------+-------+| id | int(11) | no | | null | || name | varchar(30) | yes | | null | || deptid | int(11) | yes | | null | || salary | float | yes | | null | |+--------+-------------+------+-----+---------+-------+4 rows in set (0.14 sec)
修改数据表 tb_emp2,将字段 id 设置为主键,sql 语句和运行结果如下。
mysql> alter table tb_emp2 -> add primary key(id);query ok, 0 rows affected (0.94 sec)records: 0 duplicates: 0 warnings: 0mysql> desc tb_emp2;+--------+-------------+------+-----+---------+-------+| field | type | null | key | default | extra |+--------+-------------+------+-----+---------+-------+| id | int(11) | no | pri | null | || name | varchar(30) | yes | | null | || deptid | int(11) | yes | | null | || salary | float | yes | | null | |+--------+-------------+------+-----+---------+-------+4 rows in set (0.12 sec)
以上就是mysql修改表时怎么添加主键约束?的详细内容。