MYSQL

MySQL 精华总结

一、SQL 四大分类(必须记住)

分类 全称 作用 常用命令
DDL 数据定义语言 操作数据库结构 CREATEALTERDROP
DML 数据操作语言 操作数据 INSERTUPDATEDELETE
DQL 数据查询语言 查数据 SELECT
DCL 数据控制语言 权限管理 GRANTREVOKE

二、最常用的 10 条命令(背下来)

sql

复制代码
-- 1. 查数据(最重要)
SELECT * FROM 表名 WHERE 条件;

-- 2. 插数据
INSERT INTO 表名 (列1, 列2) VALUES (值1, 值2);

-- 3. 改数据
UPDATE 表名 SET 列=新值 WHERE 条件;

-- 4. 删数据(小心!)
DELETE FROM 表名 WHERE 条件;

-- 5. 建表
CREATE TABLE 表名 (列名 数据类型, ...);

-- 6. 改表结构
ALTER TABLE 表名 ADD/DROP/MODIFY 列名;

-- 7. 排序
SELECT * FROM 表名 ORDER BY 列名 DESC/ASC;

-- 8. 分组统计
SELECT 列名, COUNT(*) FROM 表名 GROUP BY 列名;

-- 9. 分页
SELECT * FROM 表名 LIMIT 起始位置, 数量;

-- 10. 多表连接
SELECT * FROM 表A JOIN 表B ON 表A.列 = 表B.列;

三、常用数据类型(记这6个就够了)

类型 示例 用途
INT 18 整数(年龄、数量)
DECIMAL(10,2) 99.99 带小数的(价格、金额)
VARCHAR(50) "张三" 变长字符串(姓名、地址)
TEXT 长文章 长文本
DATE '2024-01-01' 日期
DATETIME '2024-01-01 12:00:00' 日期时间

四、查询条件 WHERE(核心语法)

sql

复制代码
-- 比较运算
WHERE age > 18              -- 大于
WHERE age BETWEEN 18 AND 30 -- 范围
WHERE name = '张三'          -- 等于(字符串要加引号)
WHERE name IS NULL          -- 是空(不是 = NULL!)

-- 模糊查询
WHERE name LIKE '张%'        -- 以张开头的
WHERE name LIKE '_三'        -- 第二个字是"三"的

-- 多条件
WHERE age > 18 AND city = '北京'
WHERE age > 18 OR city = '上海'
WHERE city IN ('北京', '上海', '广州')

五、分组和聚合(统计必备)

sql

复制代码
-- 5个聚合函数
COUNT(*)   -- 统计行数
SUM(列)    -- 求和
AVG(列)    -- 平均值
MAX(列)    -- 最大值
MIN(列)    -- 最小值

-- 标准分组查询模板
SELECT 
    分组列,
    COUNT(*) as 数量,
    SUM(金额列) as 总金额
FROM 表名
WHERE 筛选条件          -- 分组前筛选
GROUP BY 分组列
HAVING 分组后筛选       -- 分组后筛选
ORDER BY 总金额 DESC
LIMIT 10;

六、多表连接(3种就够了)

sql

复制代码
-- 内连接:两表都有才显示
SELECT * FROM 订单表 
JOIN 用户表 ON 订单表.user_id = 用户表.id;

-- 左连接:左表全显示,右表没有的为NULL
SELECT * FROM 用户表 
LEFT JOIN 订单表 ON 用户表.id = 订单表.user_id;

-- 右连接:右表全显示
SELECT * FROM 订单表 
RIGHT JOIN 用户表 ON 订单表.user_id = 用户表.id;

七、NULL 的坑(面试常考)

sql

复制代码
-- ❌ 错误写法
WHERE 列 = NULL    -- 永远查不到数据!
WHERE 列 != NULL   -- 也永远查不到!

-- ✅ 正确写法
WHERE 列 IS NULL
WHERE 列 IS NOT NULL

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

sql

复制代码
-- 4个步骤
BEGIN;              -- 1. 开始事务
UPDATE ...;         -- 2. 执行操作
INSERT ...;         -- 3. 执行操作
COMMIT;             -- 4. 提交(成功)
ROLLBACK;           -- 或者回滚(失败时撤销)

事务的四大特性 ACID

  • A:原子性(要么全成功,要么全失败)

  • C:一致性(数据保持正确)

  • I:隔离性(事务间互不干扰)

  • D:持久性(提交后永久保存)


九、用户权限(常用3条)

sql

复制代码
-- 创建用户
CREATE USER '用户名'@'主机' IDENTIFIED BY '密码';

-- 授权
GRANT SELECT, INSERT ON 数据库.* TO '用户名'@'主机';

-- 查看权限
SHOW GRANTS FOR '用户名'@'主机';

十、备份恢复(保命技能)

bash

复制代码
# 备份整个数据库
mysqldump -u root -p 数据库名 > backup.sql

# 恢复数据库
mysql -u root -p 数据库名 < backup.sql

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

📌 一句话记住精华

SELECT 查数据,WHERE 定条件,JOIN 连多表,GROUP BY 分组,ORDER BY 排序,LIMIT 分页,加上 ACID 事务保安全,定期备份不丢数据。

相关推荐
JZC_xiaozhong7 小时前
数据不互通、审批慢?企业多系统智能协同与流程自动化解决方案
运维·自动化·流程管理·流程自动化·数据集成与应用集成·流程监控·流程可视化设计
爱学习的小囧8 小时前
ESXi 8.0 原生支持 NVMe 固态硬盘吗?VMD 配置详解教程
linux·运维·服务器·esxi·esxi8.0
坚持就完事了8 小时前
Linux中的变量
linux·运维·服务器
hERS EOUS8 小时前
nginx 代理 redis
运维·redis·nginx
Cat_Rocky8 小时前
利用Packet Tracer网络实验
linux·运维·服务器
嵌入式×边缘AI:打怪升级日志9 小时前
Linux 驱动实战:SR501 人体红外传感器驱动开发与调试全记录
linux·运维·驱动开发
正点原子9 小时前
【正点原子Linux连载】第三章 U-Boot使用 摘自【正点原子】ATK-DLRK3568嵌入式Linux驱动开发指南
linux·运维·驱动开发
忍冬行者9 小时前
MongoDB 三节点副本集离线部署运维手册
运维·数据库·mongodb
爱学习的小囧9 小时前
ESXi VMkernel 端口 MTU 最佳设置详解
运维·服务器·网络·php·虚拟化
Elastic 中国社区官方博客11 小时前
Elastic Security、Observability 和 Search 现在在你的 AI 工具中提供交互式 UI
大数据·运维·人工智能·elasticsearch·搜索引擎·安全威胁分析·可用性测试