千家信息网

mysql添加主键的方法

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章给大家分享的是有关mysql添加主键的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。"主键(PRIMARY KEY)"的完整称呼是"主键约束"。MySQL 主键
千家信息网最后更新 2025年01月20日mysql添加主键的方法

这篇文章给大家分享的是有关mysql添加主键的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。

"主键(PRIMARY KEY)"的完整称呼是"主键约束"。MySQL 主键约束是一个列或者列的组合,其值能唯一地标识表中的每一行。这样的一列或多列称为表的主键,通过它可以强制表的实体完整性。那么在MySQL中如何添加主键约束?下面本篇文章就给大家介绍一下。

主键约束即在表中定义一个主键来唯一确定表中每一行数据的标识符。主键可以是表中的某一列或者多列的组合,其中由多列组合的主键称为复合主键。主键应该遵守下面的规则:

● 每个表只能定义一个主键。

● 主键值必须唯一标识表中的每一行,且不能为 NULL,即表中不可能存在两行数据有相同的主键值。这是唯一性原则。

● 一个列名只能在复合主键列表中出现一次。

● 复合主键不能包含不必要的多余列。当把复合主键的某一列删除后,如果剩下的列构成的主键仍然满足唯一性原则,那么这个复合主键是不正确的。这是最小化原则。

1、在创建表时添加主键约束

在 CREATE TABLE 语句中,主键是通过 PRIMARY KEY 关键字来指定的。

在定义列的同时指定主键,语法规则如下:

<字段名> <数据类型> PRIMARY KEY [默认值]

例:在 test_db 数据库中创建 tb_emp 1 数据表,其主键为 id

mysql> CREATE TABLE tb_emp1    -> (    -> id INT(11) PRIMARY KEY,    -> name VARCHAR(25),    -> deptId INT(11),    -> salary FLOAT    -> );Query OK, 0 rows affected (0.37 sec)mysql> DESC tb_emp1;+--------+-------------+------+-----+---------+-------+| 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)

在定义完所有列之后,指定主键的语法格式为:

[CONSTRAINT <约束名>] PRIMARY KEY [字段名]

示例:在 test_db 数据库中创建 tb_emp 2 数据表,其主键为 id

mysql> CREATE TABLE tb_emp2    -> (    -> id INT(11),    -> name VARCHAR(25),    -> deptId INT(11),    -> salary FLOAT,    -> PRIMARY KEY(id)    -> );Query OK, 0 rows affected (0.37 sec)mysql> DESC tb_emp2;+--------+-------------+------+-----+---------+-------+| 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)

2、在创建表后添加主键约束

创建表后,可以在修改数据表时添加主键约束,语法规则为:

ALTER TABLE <数据表名> ADD PRIMARY KEY(<列名>);

示例:修改数据表 tb_emp3,将字段 id 设置为主键

mysql> ALTER TABLE tb_emp3    -> ADD PRIMARY KEY(id);Query OK, 0 rows affected (0.94 sec)Records: 0  Duplicates: 0  Warnings: 0mysql> DESC tb_emp3;+--------+-------------+------+-----+---------+-------+| 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)

3、设置复合主键

也可以在创建表时添加复合主键,此时主键由多个字段联合组成,语法规则如下:

PRIMARY KEY [字段1,字段2,…,字段n]

示例:创建数据表 tb_emp4,假设表中没有主键 id,为了唯一确定一个员工,可以把 name、deptId 联合起来作为主键

mysql> CREATE TABLE tb_emp4    -> (    -> name VARCHAR(25),    -> deptId INT(11),    -> salary FLOAT,    -> PRIMARY KEY(id,deptId)    -> );Query OK, 0 rows affected (0.37 sec)mysql> DESC tb_emp4;+--------+-------------+------+-----+---------+-------+| Field  | Type        | Null | Key | Default | Extra |+--------+-------------+------+-----+---------+-------+| name   | varchar(25) | NO   | PRI | NULL    |       || deptId | int(11)     | NO   | PRI | NULL    |       || salary | float       | YES  |     | NULL    |       |+--------+-------------+------+-----+---------+-------+3 rows in set (0.14 sec)

感谢各位的阅读!关于mysql添加主键的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!

数据 字段 数据表 规则 语法 一行 原则 示例 组合 方法 内容 唯一性 数据库 文章 更多 标识 这是 中创 联合 不错 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 青岛奥商网络技术公司 奥迪斯服务器扶梯查看故障方法 医院信息系统网络安全情况 中国的互联网科技创新 什么是数据库的数据安全性 无锡应用刀片服务器供应 饥荒联机版的专用服务器在哪租 cdm层用什么数据库 计算机软件开发设计专业 数据库分组性能 奉化ios软件开发商 杭州安卓软件开发有哪些流程 t6管理软件怎样安装服务器 数据库合并后丢失 分离数据库mdf文件没有了 什么是数据库应用系统 视频质量诊断智能服务器 ftp服务器登录失败是怎么回事 上海忒亚网络技术有限公司 网络技术交流社区 智能汽车气候控制软件开发多少钱 金华市公安局网络安全检查 在数据库中的如下两个表 ui设计和嵌入式软件开发 宜兴重型软件开发价格实惠 软件开发是不是没有成本的 戴尔服务器手动关闭一个cpu 以下属于我国期刊数据库的是 软件开发前期无收入怎么做账 三星贴片机元件数据库对照表
0