当前位置:首页 > 行业动态 > 正文

MySQL主键的标识方法大揭秘如何设置主键

MySQL主键的标识方法有多种,可以通过设置字段属性为PRIMARY KEY、AUTO_INCREMENT等方式来设置主键。

MySQL主键的标识方法有多种,常见的有以下几种:

MySQL主键的标识方法大揭秘如何设置主键  第1张

1、自动增长(AUTO_INCREMENT)

2、指定值(NOT NULL UNIQUE)

3、组合键(多列组成)

4、UUID(通用唯一标识符)

下面分别介绍这几种方法的设置方式。

1. 自动增长(AUTO_INCREMENT)

使用AUTO_INCREMENT属性,可以使得主键的值在插入数据时自动递增,这种方式适用于自增的整数作为主键的场景。

创建表时设置主键为自动增长:

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    password VARCHAR(50) NOT NULL
);

插入数据时,不需要指定主键的值,数据库会自动为其分配一个递增的值:

INSERT INTO users (username, password) VALUES ('张三', '123456');
INSERT INTO users (username, password) VALUES ('李四', 'abcdef');

查询表中的数据,可以看到主键的值已经自动递增:

SELECT * FROM users;

2. 指定值(NOT NULL UNIQUE)

如果主键的值需要手动指定,可以使用NOT NULL和UNIQUE约束,这种方式适用于主键的值已知且不重复的场景。

创建表时设置主键为指定值:

CREATE TABLE orders (
    order_id INT NOT NULL UNIQUE,
    user_id INT NOT NULL,
    product_name VARCHAR(50) NOT NULL,
    quantity INT NOT NULL,
    PRIMARY KEY (order_id)
);

插入数据时,需要指定主键的值:

INSERT INTO orders (order_id, user_id, product_name, quantity) VALUES (1, 1, '产品A', 2);
INSERT INTO orders (order_id, user_id, product_name, quantity) VALUES (2, 2, '产品B', 1);

查询表中的数据,可以看到主键的值已经按照指定的值插入:

SELECT * FROM orders;

3. 组合键(多列组成)

如果主键由多个列组成,可以使用组合键作为主键,这种方式适用于主键的值由多个列共同决定的场景。

创建表时设置主键为组合键:

CREATE TABLE employees (
    department_id INT NOT NULL,
    employee_id INT NOT NULL,
    first_name VARCHAR(50) NOT NULL,
    last_name VARCHAR(50) NOT NULL,
    PRIMARY KEY (department_id, employee_id)
);

插入数据时,需要指定主键的所有列的值:

INSERT INTO employees (department_id, employee_id, first_name, last_name) VALUES (1, 1001, '张', '三');
INSERT INTO employees (department_id, employee_id, first_name, last_name) VALUES (2, 1002, '李', '四');

查询表中的数据,可以看到主键的值已经按照指定的列插入:

SELECT * FROM employees;
0