当前位置: 首页 > news >正文

MySQL 常用 SQL 语句大全

1. 基本查询
查询所有记录和字段

SELECT * FROM table_name;

查询特定字段

SELECT column1, column2 FROM table_name;

查询并限制结果

SELECT column1, column2 FROM table_name LIMIT 10;

条件查询

SELECT column1, column2 FROM table_name WHERE condition;

模糊匹配

SELECT column1 FROM table_name WHERE column2 LIKE 'pattern%';

匹配多个值

SELECT column1 FROM table_name WHERE column2 IN (value1, value2);

不匹配某些值

SELECT column1 FROM table_name WHERE column2 NOT IN (value1, value2);

2. 数据插入
插入单条记录

INSERT INTO table_name (column1, column2) VALUES (value1, value2);

插入多条记录

INSERT INTO table_name (column1, column2) VALUES (value1, value2), (value3, value4);

从另一个表插入数据

INSERT INTO table1 (column1, column2)
SELECT column1, column2 FROM table2 WHERE condition;

3. 数据更新
更新单条记录

UPDATE table_name SET column1 = value1 WHERE condition;

批量更新

UPDATE table_name SET column1 = value1, column2 = value2 WHERE condition;

基于其他表的更新(关联更新)

UPDATE table1
JOIN table2 ON table1.common_column = table2.common_columnSET table1.column1 = table2.column2
WHERE table2.condition;

4. 数据删除
删除单条记录

DELETE FROM table_name WHERE condition;

批量删除

DELETE FROM table_name WHERE condition;

删除表中的所有记录(也叫截断表)

TRUNCATE TABLE table_name;


5. 表操作
创建表

CREATE TABLE table_name (id INT AUTO_INCREMENT PRIMARY KEY,column1 VARCHAR(255) NOT NULL,column2 INT DEFAULT 0,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);


修改表结构

添加列

ALTER TABLE table_name ADD column_name VARCHAR(255);

删除列

ALTER TABLE table_name DROP COLUMN column_name;


修改列类型

ALTER TABLE table_name MODIFY column_name INT;

重命名列

ALTER TABLE table_name CHANGE old_column_name new_column_name VARCHAR(255);

删除表

DROP TABLE table_name;

删除数据库

DROP DATABASE database_name;

6. 索引管理
创建索引

CREATE INDEX index_name ON table_name (column_name);


创建唯一索引

CREATE UNIQUE INDEX index_name ON table_name (column_name);

删除索引

DROP INDEX index_name ON table_name;


7. 表连接
内连接(INNER JOIN)

SELECT * FROM table1
INNER JOIN table2 ON table1.common_column = table2.common_column;

左连接(LEFT JOIN)

SELECT * FROM table1
LEFT JOIN table2 ON table1.common_column = table2.common_column;

右连接(RIGHT JOIN)

SELECT * FROM table1
RIGHT JOIN table2 ON table1.common_column = table2.common_column;

全连接(FULL JOIN)

SELECT * FROM table1
LEFT JOIN table2 ON table1.common_column = table2.common_column
UNION
SELECT * FROM table1
RIGHT JOIN table2 ON table1.common_column = table2.common_column;


8. 聚合函数
计数

SELECT COUNT(*) FROM table_name;

平均值

SELECT AVG(column_name) FROM table_name;

总和

SELECT SUM(column_name) FROM table_name;

最大值

SELECT MAX(column_name) FROM table_name;

最小值

SELECT MIN(column_name) FROM table_name;

9. 分组与排序
分组

SELECT column1, COUNT(*) FROM table_name
GROUP BY column1;

排序

SELECT * FROM table_name
ORDER BY column1 ASC;SELECT * FROM table_name
ORDER BY column1 DESC;

分页

SELECT * FROM table_name
LIMIT 10 OFFSET 20;

10. 子查询
在 WHERE 子句中

SELECT * FROM table_name
WHERE column1 = (SELECT MAX(column1) FROM table_name);

在 FROM 子句中

SELECT * FROM (SELECT column1, column2 FROM table_name) AS subquery
WHERE condition;


11. 条件表达式
使用 CASE

SELECT column1,CASEWHEN condition1 THEN 'result1'WHEN condition2 THEN 'result2'ELSE 'default'END AS new_column
FROM table_name;


12. 事务管理


开始事务

START TRANSACTION;

提交事务

COMMIT;


回滚事务

ROLLBACK;


13. 备份与恢复


备份

mysqldump -u username -p database_name > backup_file.sql

恢复

mysql -u username -p database_name < backup_file.sql


14. 用户管理
创建用户

CREATE USER 'username'@'host' IDENTIFIED BY 'password';

授予权限

GRANT ALL PRIVILEGES ON database_name.* TO 'username'@'host';

撤销权限

REVOKE ALL PRIVILEGES ON database_name.* FROM 'username'@'host';

删除用户

DROP USER 'username'@'host';


15. 表和数据库信息

查看表结构

DESCRIBE table_name;

查看数据库列表

SHOW DATABASES;

查看表列表

SHOW TABLES;

查看表的索引

SHOW INDEX FROM table_name;

查看表的创建语句

SHOW CREATE TABLE table_name;

16. 查询优化

查看查询计划

EXPLAIN SELECT * FROM table_name WHERE condition;

查看慢查询日志

SHOW VARIABLES LIKE 'slow_query_log';

启用慢查询日志:

SET GLOBAL slow_query_log = 'ON';

查看当前的数据库状态

SHOW STATUS;

17. 其他实用操作

计算字段的平均值和总和

SELECT column1, AVG(column2), SUM(column2) FROM table_name GROUP BY column1;

使用 GROUP_CONCAT 函数

SELECT column1, GROUP_CONCAT(column2) FROM table_name GROUP BY column1;

这些 SQL 语句和技巧覆盖了数据库操作的广泛领域,从基础查询到高级管理和优化。掌握这些可以帮助你更高效地管理和操作 MySQL 数据库。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • LVS的简单配置及对Mysql主从复制的补充
  • 食品零食小吃商城管理系统-计算机毕设Java|springboot实战项目
  • 求职Leetcode算法题(7)
  • c语言基础知识学习
  • 井字棋游戏(HTML+CSS+JavaScript)
  • Java的反射原理
  • 天途推出无人机软硬件定制服务
  • Velero 快速上手:使用 Velero 实现 Kubernetes 集群备份与迁移
  • Java设计模式-责任链模式
  • 酷炫时尚未来科技视频开头PR模板MOGRT
  • zabbix的setup无法进入第二步
  • 单细胞irGSEA分析:整合多种富集分析方式的R包
  • 数据中台之数据开发-离线开发和实时开发
  • 超级外链工具,可发9600条优质外链
  • Linux--传输层协议UDP
  • CentOS 7 防火墙操作
  • javascript 总结(常用工具类的封装)
  • java中具有继承关系的类及其对象初始化顺序
  • Js基础——数据类型之Null和Undefined
  • Python学习之路16-使用API
  • SpiderData 2019年2月25日 DApp数据排行榜
  • 第2章 网络文档
  • 如何实现 font-size 的响应式
  • 深入 Nginx 之配置篇
  • 微信小程序填坑清单
  •  一套莫尔斯电报听写、翻译系统
  • 不要一棍子打翻所有黑盒模型,其实可以让它们发挥作用 ...
  • ​Spring Boot 分片上传文件
  • ​一文看懂数据清洗:缺失值、异常值和重复值的处理
  • #HarmonyOS:基础语法
  • (13)Latex:基于ΤΕΧ的自动排版系统——写论文必备
  • (2020)Java后端开发----(面试题和笔试题)
  • (C++17) optional的使用
  • (二) Windows 下 Sublime Text 3 安装离线插件 Anaconda
  • (完整代码)R语言中利用SVM-RFE机器学习算法筛选关键因子
  • .[hudsonL@cock.li].mkp勒索加密数据库完美恢复---惜分飞
  • .gitignore文件—git忽略文件
  • .net core 6 集成 elasticsearch 并 使用分词器
  • .NET Core中Emit的使用
  • .net FrameWork简介,数组,枚举
  • .net 无限分类
  • .Net 知识杂记
  • .NET/C# 使窗口永不获得焦点
  • .NET/C# 项目如何优雅地设置条件编译符号?
  • .NET/C# 在 64 位进程中读取 32 位进程重定向后的注册表
  • .Net转Java自学之路—基础巩固篇十三(集合)
  • /run/containerd/containerd.sock connect: connection refused
  • @KafkaListener注解详解(一)| 常用参数详解
  • @Resource和@Autowired的区别
  • [ 隧道技术 ] 反弹shell的集中常见方式(二)bash反弹shell
  • [100天算法】-不同路径 III(day 73)
  • [AIGC] MySQL存储引擎详解
  • [AX]AX2012 AIF(四):文档服务应用实例
  • [AX]AX2012 SSRS报表Drill through action
  • [C++初阶]list的模拟实现