[特殊字符] 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;
相关推荐
麦聪聊数据44 分钟前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务1 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯2 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七3 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草3 小时前
redis-9-哨兵
数据库·redis·bootstrap
明哥说编程3 小时前
Dataverse自定义表查询优化:D365集成大数据量提速实战【索引配置】
数据库·查询优化·dataverse·dataverse自定义表·索引配置·d365集成·大数据量提速
xiaowu0803 小时前
C# 拆解 “显式接口实现 + 子类强类型扩展” 的设计思想
数据库·oracle
讯方洋哥3 小时前
HarmonyOS App开发——关系型数据库应用App开发
数据库·harmonyos
惊讶的猫4 小时前
Redis持久化介绍
数据库·redis·缓存
Apple_羊先森4 小时前
ORACLE数据库巡检SQL脚本--19、磁盘读次数最高的前5条SQL语句
数据库·sql·oracle