MYSQL指令合集

一、基础 CRUD(增删查改)

1. 查询(SELECT)

bash 复制代码
SELECT * FROM table_name;
SELECT name, age FROM users;
SELECT * FROM users WHERE id = 1;
SELECT * FROM users WHERE name = 'Elias';

2. 插入(INSERT)

bash 复制代码
INSERT INTO users(name, age) VALUES ('Jack', 20);
INSERT INTO users(id, name, age) VALUES (1, 'Lily', 22);

插入多条:

bash 复制代码
INSERT INTO users(name, age)
VALUES ('A', 10), ('B', 20), ('C', 30);

3. 更新(UPDATE)

bash 复制代码
UPDATE users SET age = 25 WHERE id = 1;
UPDATE users SET name = 'Mike', age = 18 WHERE id = 2;

4. 删除(DELETE)

bash 复制代码
DELETE FROM users WHERE id = 1;
DELETE FROM users WHERE age < 10;

二、表的创建与修改

1. 创建表(包含主键)

bash 复制代码
CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(50) NOT NULL,
    age INT
);

2. 删除表

bash 复制代码
DROP TABLE users;

3. 修改表(ADD / DROP / MODIFY)

增加字段:

复制代码
ALTER TABLE users ADD email VARCHAR(100);

删除字段:

复制代码
ALTER TABLE users DROP COLUMN email;

修改字段类型:

复制代码
ALTER TABLE users MODIFY age INT NOT NULL;

修改表名:

复制代码
ALTER TABLE users RENAME TO members;

三、条件查询(WHERE)

常用条件:

bash 复制代码
SELECT * FROM users WHERE age >= 18;
SELECT * FROM users WHERE age BETWEEN 18 AND 30;
SELECT * FROM users WHERE name LIKE 'A%';   -- A 开头
SELECT * FROM users WHERE name LIKE '%abc%'; -- 包含 abc
SELECT * FROM users WHERE age IN (18, 20, 25);
SELECT * FROM users WHERE age IS NULL;
SELECT * FROM users WHERE age IS NOT NULL;

复合条件:

bash 复制代码
SELECT * FROM users WHERE age > 18 AND name = 'Jack';
SELECT * FROM users WHERE age < 18 OR age > 60;

四、排序(ORDER BY)

复制代码
SELECT * FROM users ORDER BY age DESC;
SELECT * FROM users ORDER BY age ASC, name ASC;

五、分页(LIMIT)

bash 复制代码
SELECT * FROM users LIMIT 10;        -- 前 10 条
SELECT * FROM users LIMIT 5 OFFSET 10;

前端常用分页:

复制代码
SELECT * FROM users LIMIT (page-1)*size, size;

六、连接查询(JOIN)

1. 内连接(常用)

bash 复制代码
SELECT u.name, o.order_id
FROM users u
JOIN orders o ON u.id = o.user_id;

2. 左连接(主表全部 + 匹配)

bash 复制代码
SELECT u.name, o.order_id
FROM users u
LEFT JOIN orders o ON u.id = o.user_id;

3. 右连接

bash 复制代码
SELECT u.name, o.order_id
FROM users u
RIGHT JOIN orders o ON u.id = o.user_id;

七、分组统计(GROUP BY + HAVING)

求每个年龄段人数:

复制代码
SELECT age, COUNT(*) 
FROM users 
GROUP BY age;

统计后过滤(HAVING):

复制代码
SELECT age, COUNT(*) AS cnt
FROM users
GROUP BY age
HAVING cnt >= 2;

求平均值:

复制代码
SELECT AVG(age) FROM users;
SELECT SUM(age), MIN(age), MAX(age) FROM users;

八、子查询

复制代码
SELECT * FROM users 
WHERE age > (SELECT AVG(age) FROM users);

SELECT name FROM users 
WHERE id IN (SELECT user_id FROM orders);

九、索引(提高查询速度)

1. 创建索引

复制代码
CREATE INDEX idx_name ON users(name);

2. 删除索引

复制代码
DROP INDEX idx_name ON users;

3. 唯一索引

复制代码
CREATE UNIQUE INDEX idx_email ON users(email);

十、约束(提高数据可靠性)

主键

复制代码
PRIMARY KEY (id)

唯一

复制代码
UNIQUE(email)

外键

复制代码
CONSTRAINT fk_user
FOREIGN KEY(user_id) REFERENCES users(id)

十一、事务(保证数据一致性)

开启事务:

复制代码
START TRANSACTION;

修改:

复制代码
UPDATE users SET age = age - 1 WHERE id = 1;
UPDATE users SET age = age + 1 WHERE id = 2;

提交:

复制代码
COMMIT;

回滚:

复制代码
ROLLBACK;

十二、数据库/表管理

切换数据库:

复制代码
USE dbname;

查看所有数据库:

复制代码
SHOW DATABASES;

查看所有表:

复制代码
SHOW TABLES;

查看表结构:

复制代码
DESC users;

十三、字符集(防止中文乱码)

复制代码
SET NAMES utf8mb4;

或 C++ 设置:

复制代码
mysql_options(conn, MYSQL_SET_CHARSET_NAME, "utf8mb4");

一个"真实项目常用 SQL 组合"

创建用户表 + 插入用户 + 查询用户 + 登录验证

复制代码
CREATE TABLE user(
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(50) UNIQUE,
    password VARCHAR(100),
    create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

INSERT INTO user(name, password) VALUES ('Elias', '123456');

SELECT id, name FROM user WHERE name='Elias' AND password='123456';
相关推荐
香蕉鼠片几秒前
Mysql进阶篇
数据库·mysql·oracle
数厘2 分钟前
2.12 sql 数据插入(INSERT INTO)
数据库·sql·oracle
薛定e的猫咪3 分钟前
2026 年 4 月实测:OpenAI Codex 保姆级教程,从安装到 MCP、Skills 与多智能体协作
前端·数据库·人工智能
wgzrmlrm744 分钟前
Django怎么优雅发送邮件_Python配置SMTP后端实现异步通知
jvm·数据库·python
014-code6 分钟前
Redis 删除缓存失败怎么办?重试、死信、补偿的工程化方案
数据库·redis·缓存
I love studying!!!7 分钟前
Web应用程序:用户账户
前端·数据库·sqlite
quxuexi9 分钟前
MySQL B+树与复合索引完全指南:从底层原理到高性能优化
b树·mysql·性能优化
窝子面10 分钟前
NestJs+MongoDB+Deepseek+Langchain实现ai聊天助手
javascript·数据库·人工智能·mongodb
y = xⁿ12 分钟前
【保姆级 :图解MySQL 执行全链路讲解】主键索引扫描,全局扫描,索引下推还是分不清楚?这一篇就够啦
android·mysql
zjshuster12 分钟前
流程引擎(Process Engine)简介
java·数据库·servlet