前言
CRUD是MySQL最基础、最常用的核心操作,对应插入(Create)、查询(Read)、修改(Update)、删除(Delete),也是新手入门MySQL的第一个实操重点。
很多新手刚学的时候,要么语句写错、要么条件遗漏,导致操作失败。这篇文章全程用「可直接复制运行」的示例,手把手教你CRUD每一步,搭配避坑提示,新手也能零错误上手。
先准备测试表(所有示例均基于此表,复制即可创建):
sql
-- 创建测试表:user(用户表)
CREATE TABLE user (
id INT PRIMARY KEY AUTO_INCREMENT, -- 自增主键
name VARCHAR(20) NOT NULL, -- 用户名(非空)
age INT, -- 年龄
gender TINYINT, -- 性别(1=男,2=女)
email VARCHAR(50) UNIQUE, -- 邮箱(唯一)
create_time DATETIME DEFAULT NOW() -- 创建时间(默认当前时间)
);
一、插入操作(Create):INSERT
1. 基础插入(指定字段)
最常用、最安全的方式,明确指定要插入的字段,避免字段顺序错乱导致报错。
sql
-- 插入1条数据
INSERT INTO user (name, age, gender, email)
VALUES ('张三', 20, 1, 'zhangsan@163.com');
-- 插入多条数据(逗号分隔,效率更高)
INSERT INTO user (name, age, gender, email)
VALUES
('李四', 22, 1, 'lisi@163.com'),
('王五', 19, 2, 'wangwu@163.com'),
('赵六', 21, 1, 'zhaoliu@163.com');
2. 简化插入(不指定字段)
需严格按照表中字段顺序插入,且不能遗漏非空字段,不推荐新手使用。
sql
INSERT INTO user
VALUES (NULL, '孙七', 23, 2, 'sunqi@163.com', DEFAULT);
-- 说明:主键自增可填NULL,DEFAULT表示使用字段默认值(此处为当前时间)
插入避坑
❌ 错误:插入非空字段(如name)时不赋值,会报错;
❌ 错误:插入唯一字段(如email)时,值重复,会报错;
✅ 正确:插入前确认非空字段、唯一字段的值合规。
二、查询操作(Read):SELECT
查询是开发中使用频率最高的操作,先掌握基础查询,后续再学进阶用法。
1. 查询所有数据(全表查询)
sql
-- 查用户名、年龄、邮箱
SELECT name, age, email FROM user;
2. 查询指定字段
只查需要的字段,避免全表查询浪费性能,推荐使用。
sql
-- 查用户名、年龄、邮箱
SELECT name, age, email FROM user;
3. 去重查询(DISTINCT)
当字段有重复值时,只显示唯一值。
sql
-- 查所有不重复的性别
SELECT DISTINCT gender FROM user;
三、修改操作(Update):UPDATE
修改表中已存在的数据,必须加WHERE条件,否则会修改全表数据,极其危险!
1. 基础修改(指定条件)
sql
-- 修改张三的年龄为21
UPDATE user
SET age = 21
WHERE name = '张三';
-- 修改王五的邮箱和性别
UPDATE user
SET email = 'wangwu@qq.com', gender = 1
WHERE id = 3; -- 用主键作为条件,更精准、更安全
2. 批量修改(谨慎使用)
多条件匹配,批量修改符合条件的数据,务必确认条件无误。
sql
-- 修改所有年龄>20的用户,性别改为1
UPDATE user
SET gender = 1
WHERE age > 20;
修改避坑
❌ 错误:忘记加WHERE条件,导致全表数据被修改;
❌ 错误:修改唯一字段时,值重复,会报错;
✅ 正确:修改前先执行SELECT查询,确认条件匹配的是目标数据。
四、删除操作(Delete):DELETE
删除表中数据,同样必须加WHERE条件,否则会删除全表数据,无法恢复(无备份情况下)。
1. 基础删除(指定条件)
sql
-- 删除名字为孙七的用户
DELETE FROM user
WHERE name = '孙七';
-- 删除id为4的用户(主键删除,最安全)
DELETE FROM user
WHERE id = 4;
2. 批量删除
sql
-- 删除年龄<20的用户
DELETE FROM user
WHERE age < 20;
3. 清空表(TRUNCATE)
清空全表数据,且重置自增主键(和DELETE删除全表的区别:DELETE不重置自增)。
sql
-- 清空user表所有数据,自增主键从1重新开始
TRUNCATE TABLE user;
删除避坑
❌ 错误:忘记加WHERE条件,删除全表数据;
❌ 错误:用DELETE清空表后,自增主键不会重置;
✅ 正确:日常删除用DELETE+WHERE,清空表用TRUNCATE(确认无需保留数据)。
五、CRUD总结
-
插入:INSERT INTO ... VALUES ...(多数据用逗号分隔);
-
查询:SELECT 字段 FROM 表名(* 表示所有字段);
-
修改:UPDATE 表名 SET 字段=值 WHERE 条件(必加WHERE);
-
删除:DELETE FROM 表名 WHERE 条件(必加WHERE),清空用TRUNCATE。