[特殊字符] MySQL 常用指令大全

### 文章目录

  • [@[TOC]](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**一、数据库操作**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**二、数据表操作**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**三、数据操作(CRUD)**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**四、备份与恢复**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**五、用户与权限管理**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**六、高级查询**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**七、索引管理**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)
  • [**八、性能与状态**](#文章目录 @[TOC] 一、数据库操作 二、数据表操作 三、数据操作(CRUD) 四、备份与恢复 五、用户与权限管理 六、高级查询 七、索引管理 八、性能与状态)

一、数据库操作

sql 复制代码
-- 查看所有数据库
SHOW DATABASES;

-- 创建数据库(指定字符集)
CREATE DATABASE db_name CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

-- 使用/切换数据库
USE db_name;

-- 删除数据库
DROP DATABASE db_name;

-- 查看当前数据库
SELECT DATABASE();

二、数据表操作

sql 复制代码
-- 查看所有表
SHOW TABLES;

-- 查看表结构
DESC table_name;
-- 或
SHOW CREATE TABLE table_name;

-- 创建表
CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(50) NOT NULL UNIQUE,
    email VARCHAR(100),
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    INDEX idx_username (username)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

-- 修改表
ALTER TABLE users ADD COLUMN age INT;
ALTER TABLE users MODIFY COLUMN email VARCHAR(150);
ALTER TABLE users DROP COLUMN age;

-- 删除表
DROP TABLE users;

-- 清空表(保留结构)
TRUNCATE TABLE users;

三、数据操作(CRUD)

sql 复制代码
-- 插入数据
INSERT INTO users (username, email) VALUES ('zhangsan', 'zs@example.com');
INSERT INTO users VALUES (1, 'lisi', 'ls@example.com', NOW());

-- 查询数据
SELECT * FROM users;
SELECT id, username FROM users WHERE email IS NOT NULL ORDER BY created_at DESC LIMIT 10;

-- 更新数据
UPDATE users SET email = 'new@example.com' WHERE username = 'zhangsan';

-- 删除数据
DELETE FROM users WHERE id = 1;

四、备份与恢复

bash 复制代码
# 导出整个数据库
mysqldump -u root -p db_name > /path/backup.sql

# 导出多个数据库
mysqldump -u root -p --databases db1 db2 > backup.sql

# 导出所有数据库
mysqldump -u root -p --all-databases > all_backup.sql

# 导出指定表
mysqldump -u root -p db_name table1 table2 > tables_backup.sql

# 只导出表结构(不含数据)
mysqldump -u root -p --no-data db_name > structure.sql

# 远程导出
mysqldump -h host -P port -u user -p db_name > backup.sql
sql 复制代码
-- 导入SQL文件(MySQL命令行内)
SOURCE /path/backup.sql;

-- 导入指定数据库
mysql -u root -p db_name < backup.sql

五、用户与权限管理

sql 复制代码
-- 创建用户
CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'password';

-- 授权
GRANT ALL PRIVILEGES ON db_name.* TO 'newuser'@'localhost';
GRANT SELECT, INSERT ON db_name.table1 TO 'newuser'@'%';

-- 刷新权限
FLUSH PRIVILEGES;

-- 查看用户权限
SHOW GRANTS FOR 'newuser'@'localhost';

-- 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';

-- 删除用户
DROP USER 'newuser'@'localhost';

六、高级查询

sql 复制代码
-- 去重
SELECT DISTINCT column FROM table;

-- 分组统计
SELECT department, COUNT(*) FROM employees GROUP BY department HAVING COUNT(*) > 5;

-- 联表查询
SELECT a.*, b.name FROM orders a LEFT JOIN customers b ON a.customer_id = b.id;

-- 子查询
SELECT * FROM products WHERE price > (SELECT AVG(price) FROM products);

-- 分页查询
SELECT * FROM table LIMIT 10 OFFSET 20;  -- 第3页,每页10条
SELECT * FROM table LIMIT 20, 10;         -- 同上

七、索引管理

sql 复制代码
-- 查看索引
SHOW INDEX FROM table_name;

-- 创建索引
CREATE INDEX idx_name ON table_name(column);
CREATE UNIQUE INDEX idx_unique ON table_name(column);

-- 删除索引
DROP INDEX idx_name ON table_name;

-- 添加主键
ALTER TABLE table_name ADD PRIMARY KEY (id);

八、性能与状态

sql 复制代码
-- 查看MySQL版本
SELECT VERSION();

-- 查看当前连接
SHOW PROCESSLIST;

-- 查看表状态
SHOW TABLE STATUS;

-- 查看慢查询日志是否开启
SHOW VARIABLES LIKE 'slow_query_log%';

-- 分析查询
EXPLAIN SELECT * FROM users WHERE username = 'zhangsan';

💡 小贴士

  • 生产环境操作前务必先备份:mysqldump
  • 大数据量删除用 TRUNCATEDELETE 快,但不可回滚
  • 字符串类型推荐用 utf8mb4 支持emoji
  • 重要操作先 BEGIN; 测试,确认无误再 COMMIT;
相关推荐
卓怡学长2 小时前
m115乐购游戏商城系统
java·前端·数据库·spring boot·spring·游戏
小句3 小时前
SQL中JOIN语法详解 GROUP BY语法详解
数据库·sql
阿杰 AJie3 小时前
MySQL 里给表添加索引
数据库·mysql
昊昊该干饭了3 小时前
一个真实查询需求如何从表设计走到高效 SQL
数据库·sql
Ha_To4 小时前
2026.1.20 SQL Server命令
数据库
智在碧得4 小时前
碧服打造DataOps全链路闭环,定义大数据工程化发布新标杆
大数据·网络·数据库
IvorySQL5 小时前
PostgreSQL 性能:云端与本地的延迟分析
数据库·postgresql
wangbing11255 小时前
分组取前几位
数据库
给我来一根5 小时前
用户认证与授权:使用JWT保护你的API
jvm·数据库·python