可通过SHOW INDEXES、DESCRIBE和查询information_schema三种方法查看mysql表主键;SHOW INDEXES适用于查看单列或复合主键的列及顺序,DESCRIBE通过Key列为PRI识别主键,查询information_schema可精确获取主键列名及位置;复合主键需结合Seq_in_index或ORDINAL_POSITION判断组成列;主键选择影响查询、插入、更新性能及存储开销,应优先选择唯一、稳定、短小且查询频繁的列;可使用ALTER table语句添加或删除主键,添加时需确保列值唯一,删除主键会移除外键约束;主键与唯一索引区别在于主键不允许NULL且一个表仅能有一个,而唯一索引允许多个NULL值且可创建多个,主键通常为聚簇索引,唯一索引为非聚簇索引,主键更适合作为外键引用。
直接查看MySQL表的主键信息,可以通过几种方法快速实现,包括使用
SHOW INDEXES
、
DESCRIBE
语句,以及查询
information_schema
数据库。这些方法各有侧重,可以根据实际需求选择。
解决方案
查看MySQL表主键信息,主要有以下几种方法:
-
使用
SHOW INDEXES
语句
这是最常用的方法之一,可以显示表的所有索引信息,包括主键。
SHOW INDEXES FROM your_table_name;
执行结果会包含多个字段,其中
Key_name
列显示索引的名称,主键的
Key_name
通常是
PRIMARY
。
Column_name
列显示索引对应的列名。
Non_unique
列如果值为0,表示是唯一索引,主键肯定是唯一索引。
例如,查看
users
表的主键信息:
SHOW INDEXES FROM users;
结果示例:
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+ | Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment | +-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+ | users | 0 | PRIMARY | 1 | id | A | 10 | NULL | NULL | | BTREE | | | +-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
从结果中可以看到,
Key_name
为
PRIMARY
,
Column_name
为
id
,说明
id
列是主键。
-
使用
DESCRIBE
语句 (或
DESC
)
DESCRIBE
语句可以显示表的结构,包括字段名、数据类型、是否允许为空、键信息等。
DESCRIBE your_table_name;
或者简写为:
DESC your_table_name;
执行结果中,
Key
列会显示键信息。如果某列是主键,则
Key
列的值为
PRI
。
例如,查看
users
表的结构:
DESCRIBE users;
结果示例:
+-------+---------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+---------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | varchar(255) | YES | | NULL | | | email | varchar(255) | YES | UNI | NULL | | +-------+---------+------+-----+---------+----------------+
从结果中可以看到,
id
列的
Key
值为
PRI
,说明
id
列是主键。
email
列的
Key
值为
UNI
,说明
email
列是唯一索引。
-
查询
information_schema
数据库
information_schema
数据库存储了MySQL服务器的元数据信息,包括数据库、表、列、索引等。可以通过查询
information_schema.KEY_COLUMN_USAGE
表来获取主键信息。
SELECT COLUMN_NAME FROM information_schema.KEY_COLUMN_USAGE WHERE TABLE_NAME = 'your_table_name' AND CONSTRAINT_NAME = 'PRIMARY' AND TABLE_SCHEMA = 'your_database_name';
需要将
your_table_name
替换为你的表名,
your_database_name
替换为你的数据库名。
例如,查询
mydatabase
数据库中
users
表的主键信息:
SELECT COLUMN_NAME FROM information_schema.KEY_COLUMN_USAGE WHERE TABLE_NAME = 'users' AND CONSTRAINT_NAME = 'PRIMARY' AND TABLE_SCHEMA = 'mydatabase';
结果示例:
+-------------+ | COLUMN_NAME | +-------------+ | id | +-------------+
结果显示
id
列是主键。
如何确定复合主键的组成列?
如果表有复合主键(即主键由多个列组成),
SHOW INDEXES
和查询
information_schema
是更有效的方法。
DESCRIBE
语句只能显示每列的信息,不能直接看出哪些列共同组成了主键。
-
使用
SHOW INDEXES
对于复合主键,
SHOW INDEXES
会显示多行
Key_name
为
PRIMARY
的记录,每一行对应主键中的一个列。
Seq_in_index
列表示该列在主键中的顺序。
SHOW INDEXES FROM your_table_name;
例如,如果
orders
表的主键由
order_id
和
product_id
组成:
SHOW INDEXES FROM orders;
结果示例:
+--------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+ | Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment | +--------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+ | orders | 0 | PRIMARY | 1 | order_id | A | 10 | NULL | NULL | | BTREE | | | | orders | 0 | PRIMARY | 2 | product_id | A | 10 | NULL | NULL | | BTREE | | | +--------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
可以看到,
Key_name
都是
PRIMARY
,
Seq_in_index
分别为 1 和 2,对应的
Column_name
分别为
order_id
和
product_id
,说明
order_id
和
product_id
共同组成了主键。
-
查询
information_schema
查询
information_schema.KEY_COLUMN_USAGE
表也可以获取复合主键的组成列。
SELECT COLUMN_NAME, ORDINAL_POSITION FROM information_schema.KEY_COLUMN_USAGE WHERE TABLE_NAME = 'your_table_name' AND CONSTRAINT_NAME = 'PRIMARY' AND TABLE_SCHEMA = 'your_database_name' ORDER BY ORDINAL_POSITION;
ORDINAL_POSITION
列表示该列在主键中的顺序。
例如,查询
mydatabase
数据库中
orders
表的主键信息:
SELECT COLUMN_NAME, ORDINAL_POSITION FROM information_schema.KEY_COLUMN_USAGE WHERE TABLE_NAME = 'orders' AND CONSTRAINT_NAME = 'PRIMARY' AND TABLE_SCHEMA = 'mydatabase' ORDER BY ORDINAL_POSITION;
结果示例:
+-------------+------------------+ | COLUMN_NAME | ORDINAL_POSITION | +-------------+------------------+ | order_id | 1 | | product_id | 2 | +-------------+------------------+
结果显示
order_id
和
product_id
共同组成了主键,并且
order_id
是第一列,
product_id
是第二列。
主键的选择对性能有什么影响?
主键的选择对数据库性能有显著影响,主要体现在以下几个方面:
-
查询性能:
主键通常被用于
WHERE
子句中进行快速查找。选择合适的列作为主键可以提高查询速度。如果经常需要根据某个字段进行查询,将该字段设为主键或主键的一部分,可以利用主键索引的优势,加快查询速度。
-
索引大小:
主键索引会占用存储空间。较长的主键(例如,使用较长的字符串作为主键)会增加索引的大小,从而影响查询性能和存储成本。因此,选择较短的数据类型作为主键通常是更好的选择。
-
插入性能:
在插入新记录时,数据库需要维护主键索引。如果主键是自增的,插入性能通常较高,因为新记录可以顺序添加到索引中。如果主键不是自增的,插入性能可能会下降,因为数据库需要在索引中查找合适的位置插入新记录。
-
更新性能:
更新主键的值通常代价较高,因为需要更新索引。应尽量避免频繁更新主键的值。如果确实需要更新主键的值,应考虑对性能的影响。
-
外键约束:
主键通常被其他表用作外键。如果主键的类型或大小发生变化,所有引用该主键的外键也需要相应地修改。因此,在选择主键时,应考虑到外键约束的影响。
总的来说,选择主键时应考虑以下因素:
- 唯一性:主键必须唯一标识表中的每一行。
- 稳定性:主键的值应尽量稳定,避免频繁更新。
- 简洁性:主键的数据类型应尽量简单,长度应尽量短。
- 查询频率:如果经常需要根据某个字段进行查询,应将该字段设为主键或主键的一部分。
如何在已存在的表中添加或删除主键?
在MySQL中,可以在已存在的表中添加或删除主键。
-
添加主键
如果表没有主键,可以使用
ALTER TABLE
语句添加主键。
ALTER TABLE your_table_name ADD PRIMARY KEY (column_name);
如果表已经存在数据,
Column_name
列的值必须是唯一的,否则添加主键会失败。
例如,给
users
表的
id
列添加主键:
ALTER TABLE users ADD PRIMARY KEY (id);
如果需要添加复合主键,可以指定多个列:
ALTER TABLE your_table_name ADD PRIMARY KEY (column1, column2);
例如,给
orders
表的
order_id
和
product_id
列添加复合主键:
ALTER TABLE orders ADD PRIMARY KEY (order_id, product_id);
-
删除主键
可以使用
ALTER TABLE
语句删除主键。
ALTER TABLE your_table_name DROP PRIMARY KEY;
注意,一个表只能有一个主键。删除主键后,如果其他表有外键引用该主键,外键约束也会被删除。
例如,删除
users
表的主键:
ALTER TABLE users DROP PRIMARY KEY;
如果主键是自增的,删除主键后,自增属性不会被删除,需要手动删除自增属性。
主键和唯一索引有什么区别?
主键和唯一索引都用于保证表中列的唯一性,但它们之间存在一些关键区别:
-
唯一性:
- 主键:主键必须唯一标识表中的每一行,不允许有
NULL
值。
- 唯一索引:唯一索引也要求列的值唯一,但允许有
NULL
值(MySQL 5.7 及更早版本中,允许一个
NULL
值;MySQL 8.0 及更高版本中,允许多个
NULL
值)。
- 主键:主键必须唯一标识表中的每一行,不允许有
-
数量:
- 主键:一个表只能有一个主键。
- 唯一索引:一个表可以有多个唯一索引。
-
用途:
- 主键:主键用于唯一标识表中的每一行,是表的核心约束。
- 唯一索引:唯一索引用于保证列的唯一性,提高查询性能。
-
索引类型:
-
外键约束:
- 主键:主键通常被其他表用作外键,建立表之间的关联关系。
- 唯一索引:唯一索引也可以被其他表用作外键,但通常不建议这样做,因为主键更能体现表之间的关系。
总的来说,主键是表的核心约束,用于唯一标识表中的每一行,而唯一索引是用于保证列的唯一性,提高查询性能。在选择主键和唯一索引时,应根据实际需求进行权衡。
评论(已关闭)
评论已关闭