常用的 ​​SQL 语句分类整理​​

news2025/4/21 21:17:29

以下是常用的 ​​SQL 语句分类整理​​,覆盖数据查询、操作、表管理和高级功能,适用于大多数关系型数据库(如 MySQL、PostgreSQL、SQL Server):


目录

​​一、数据查询(DQL)​​

​​1. 基础查询​​

​​2. 条件过滤(WHERE)​​

​​3. 排序与分页​​

​​二、数据操作(DML)​​

​​1. 插入数据(INSERT)​​

​​2. 更新数据(UPDATE)​​

​​3. 删除数据(DELETE)​​

​​三、表管理(DDL)​​

​​1. 创建表(CREATE TABLE)​​

​​2. 修改表(ALTER TABLE)​​

​​3. 删除表(DROP TABLE)​​

​​四、高级查询​​

​​1. 聚合函数(GROUP BY)​​

​​2. 多表连接(JOIN)​​

​​3. 子查询​​

​​五、实用功能​​

​​1. 日期处理​​

​​2. 字符串处理​​

​​3. 窗口函数​​

​​六、性能优化技巧​​


​一、数据查询(DQL)​

​1. 基础查询​

-- 查询所有字段
SELECT * FROM employees;

-- 查询特定字段
SELECT first_name, last_name FROM employees;

-- 去重查询
SELECT DISTINCT department FROM employees;

​2. 条件过滤(WHERE)​

-- 简单条件
SELECT * FROM orders WHERE amount > 1000;

-- 多条件组合(AND/OR)
SELECT * FROM products 
WHERE price BETWEEN 50 AND 100 
AND category = 'Electronics';

-- 模糊匹配(LIKE)
SELECT * FROM customers 
WHERE email LIKE '%@gmail.com';

-- IN 运算符
SELECT * FROM employees 
WHERE department_id IN (10, 20, 30);

​3. 排序与分页​

-- 排序(ASC/DESC)
SELECT * FROM products 
ORDER BY price DESC, stock_quantity ASC;

-- 分页(MySQL)
SELECT * FROM orders 
LIMIT 10 OFFSET 20;  
//限制返回 ​​10 条记录​​,即每页显示 10 条数据,跳过前 ​​20 条记录​​,从第 ​​21 条​​ 开始取数据

-- 分页(SQL Server)
SELECT * FROM orders 
ORDER BY order_date 
OFFSET 20 ROWS FETCH NEXT 10 ROWS ONLY;

​二、数据操作(DML)​

​1. 插入数据(INSERT)​

-- 插入单条数据
INSERT INTO users (username, email, created_at)
VALUES ('john_doe', 'john@example.com', NOW());

-- 插入多条数据
INSERT INTO products (name, price)
VALUES 
  ('Laptop', 999.99),
  ('Mouse', 29.99),
  ('Keyboard', 49.99);

​2. 更新数据(UPDATE)​

-- 更新单字段
UPDATE employees 
SET salary = salary * 1.05 
WHERE department = 'Engineering';

-- 更新多字段
UPDATE orders 
SET status = 'Shipped', shipped_date = CURRENT_DATE 
WHERE order_id = 1001;

​3. 删除数据(DELETE)​

-- 删除特定记录
DELETE FROM logs 
WHERE created_at < '2023-01-01';

-- 清空表(慎用!)
TRUNCATE TABLE temp_data;

​三、表管理(DDL)​

​1. 创建表(CREATE TABLE)​

CREATE TABLE employees (
  employee_id INT PRIMARY KEY AUTO_INCREMENT,
  first_name VARCHAR(50) NOT NULL,
  last_name VARCHAR(50),
  hire_date DATE,
  salary DECIMAL(10, 2),
  department_id INT,
  FOREIGN KEY (department_id) REFERENCES departments(department_id)
);

​2. 修改表(ALTER TABLE)​

-- 添加列
ALTER TABLE users 
ADD COLUMN phone_number VARCHAR(15);

-- 修改列类型
ALTER TABLE products 
ALTER COLUMN price TYPE DECIMAL(12, 2);

-- 删除列
ALTER TABLE orders 
DROP COLUMN old_reference;

​3. 删除表(DROP TABLE)​

DROP TABLE backup_data;  -- 删除表结构及数据

​四、高级查询​

​1. 聚合函数(GROUP BY)​

-- 统计每个部门的平均工资
SELECT department, AVG(salary) AS avg_salary
FROM employees
GROUP BY department
HAVING AVG(salary) > 5000;  -- HAVING过滤聚合结果

​2. 多表连接(JOIN)​

-- 内连接
SELECT o.order_id, c.customer_name
FROM orders o
JOIN customers c ON o.customer_id = c.customer_id;

-- 左连接(包含未匹配的订单)
SELECT o.order_id, c.customer_name
FROM orders o
LEFT JOIN customers c ON o.customer_id = c.customer_id;

-- 自连接(查找员工的上级)
SELECT e.employee_id, m.manager_name
FROM employees e
JOIN employees m ON e.manager_id = m.employee_id;

​3. 子查询​

-- 子查询在WHERE中
SELECT product_name 
FROM products 
WHERE category_id IN (
  SELECT category_id 
  FROM categories 
  WHERE category_name = 'Books'
);

-- 关联子查询
SELECT e.first_name, e.salary
FROM employees e
WHERE salary > (
  SELECT AVG(salary) 
  FROM employees 
  WHERE department = e.department
);

​五、实用功能​

​1. 日期处理​

-- 当前日期
SELECT CURRENT_DATE;

-- 日期格式化(MySQL)
SELECT DATE_FORMAT(created_at, '%Y-%m') AS month
FROM orders;

-- 日期计算(PostgreSQL)
SELECT order_date + INTERVAL '7 days' AS due_date
FROM orders;

​2. 字符串处理​

-- 拼接字符串(SQL Server)
SELECT first_name + ' ' + last_name AS full_name 
FROM employees;

-- 截取子串(MySQL)
SELECT SUBSTRING(email, 1, 5) AS prefix 
FROM users;

-- 替换文本(PostgreSQL)
SELECT REPLACE(description, 'old', 'new') 
FROM products;

​3. 窗口函数​

-- 计算排名
SELECT 
  product_id,
  sales,
  RANK() OVER (ORDER BY sales DESC) AS sales_rank
FROM products;

-- 累计求和
SELECT 
  order_date,
  amount,
  SUM(amount) OVER (ORDER BY order_date) AS running_total
FROM orders;

​六、性能优化技巧​

  1. ​索引使用​

    -- 创建索引
    CREATE INDEX idx_customer_email ON customers(email);
  2. ​执行计划分析​

    EXPLAIN SELECT * FROM orders WHERE status = 'Shipped';
  3. ​避免全表扫描​

    • 对WHERE条件列添加索引
    • 避免在WHERE中对字段进行函数操作(如 WHERE YEAR(date) = 2023 → 改为范围查询)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2339672.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

驱动开发硬核特训 · Day 15:电源管理核心知识与实战解析

在嵌入式系统中&#xff0c;电源管理&#xff08;Power Management&#xff09;并不是“可选项”&#xff0c;而是实际部署中影响系统稳定性、功耗、安全性的重要一环。今天我们将以 Linux 电源管理框架 为基础&#xff0c;从理论结构、内核架构&#xff0c;再到典型驱动实战&a…

【零基础】基于DeepSeek-R1与Qwen2.5Max的行业洞察自动化平台

自动生成行业报告,通过调用两个不同的大模型(DeepSeek 和 Qwen),完成从行业趋势分析到结构化报告生成的全过程。 完整代码:https://mp.weixin.qq.com/s/6pHi_aIDBcJKw1U61n1uUg 🧠 1. 整体目的与功能 该脚本实现了一个名为 ReportGenerator 的类,用于: 调用 DeepSe…

C 语言联合与枚举:自定义类型的核心解析

目录 1.联合体 1.1联合体的声明与创建 1.2联合体在内存中的存储 1.3相同成员的结构体与内存比较 1.4联合体内存空间大小的计算 1.5联合体的应用 2.枚举类型 2.1枚举变量的声明 2.2枚举变量的优点 2.3枚举的使用 上篇博客中&#xff0c;我们通过学习了解了C语言中一种自…

基于Canal+Spring Boot+Kafka的MySQL数据变更实时监听实战指南

前期知识背景 binlog 什么是binlog 它记录了所有的DDL和DML(除 了数据查询语句)语句&#xff0c;以事件形式记录&#xff0c;还包含语句所执行的消耗的时间&#xff0c;MySQL 的二进制日志是事务安全型的。一般来说开启二进制日志大概会有1%的性能损耗。 binlog分类 MySQL Bi…

MySQL运维三部曲初级篇:从零开始打造稳定高效的数据库环境

文章目录 一、服务器选型——给数据库一个舒适的家二、系统调优——打造高性能跑道三、MySQL配置——让数据库火力全开四、监控体系——数据库的体检中心五、备份恢复——数据安全的最后防线六、主从复制——数据同步的艺术七、安全加固——守护数据长城 引言&#xff1a;从小白…

【MySQL】MySQL的基础语法及其语句的介绍

1、基础语法 mysql -h【主机名】 -u【用户名】 -p //登录MySQL exit或quit; //退出MySQL show database; //查看MySQL下的所有数据库 use 【数据库名】; //进入数据库 show tables; //查看数据库下的所有表名 *MySQL的启动和关闭 &am…

【计算机视觉】三维视觉项目 - Colmap二维图像重建三维场景

COLMAP 3D重建 项目概述项目功能项目运行方式1. 环境准备2. 编译 COLMAP3. 数据准备4. 运行 COLMAP 常见问题及解决方法1. **编译问题**2. **运行问题**3. **数据问题** 项目实战建议项目参考文献 项目概述 COLMAP 是一个开源的三维重建软件&#xff0c;专注于 Structure-from…

ALSA架构学习2(驱动MAX98357A)

1 前言和环境 之前其实写过两篇&#xff0c;一篇是讲ALSA&#xff0c;一篇是I2S。 ALSA架构学习1&#xff08;框架&#xff09;_alsa框架学习-CSDN博客 总线学习5--I2S_max98357接喇叭教程-CSDN博客 在ALSA那篇的结尾&#xff0c;也提了几个小练习。比如&#xff1a; ### 4…

数据结构*集合框架顺序表-ArrayList

集合框架 常见的集合框架 什么是顺序表 顺序表是一种线性表数据结构&#xff0c;它借助一组连续的存储单元来依次存储线性表中的数据元素。一般情况下采用数组存储。 在数组上完成数据的增删查改。 自定义简易版的顺序表 代码展示&#xff1a; public interface IArray…

VMware Workstation 保姆级 Linux(CentOS) 创建教程(附 iso)

文章目录 一、下载二、创建 一、下载 CentOS-7.9-x86_64-DVD-2009.iso 二、创建 VMware Workstation 保姆级安装教程(附安装包) VMware Workstation 保姆级安装教程(附安装包) VMware Workstation 保姆级安装教程(附安装包)

软考-信息系统项目管理师-2 信息技术发展

总结思维导图 云计算(掌握) (3)多租户和访问控制管理访问控制管理是云计算应用的核心问题之一云计算访问控制的研究主要集中在云计算访问控制模型、基于ABE密码体制的云计算访问控制、云中多租户及虚拟化访问控制研究云中多租户及虚拟化访问控制是云计算的典型特征。 大数据(…

Spring Boot JPA 开发之Not an entity血案

项目状况介绍 项目环境 JDK 21Spring Boot 3.4.3Hibernate: 6.6.13.Final项目描述 因为是微服务架构,项目层级如下 project-parent project-com project-A … project-X 其中: project-parent定义依赖库的版本project-com 定义了一些公用的方法和配置,包括持久层的配置。…

HTMLCSS实现轮播图效果

这段代码实现了一个具有自动轮播、手动切换功能的图片轮播图&#xff0c;并且配有指示器&#xff08;小圆点&#xff09;来显示当前图片位置。轮播图可通过左右箭头按钮进行手动切换&#xff0c;也能自动定时切换&#xff0c;当鼠标悬停在轮播图上时&#xff0c;自动轮播会暂停…

嵌入式学习——opencv图像库编程

环境配置 OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和图像处理库&#xff0c;广泛用于各种计算机视觉任务&#xff0c;如图像处理、视频分析、人脸识别、物体检测、机器学习等。它提供了丰富的函数和工具&#xff0c;用于处理…

【每日八股】复习 MySQL Day1:事务

文章目录 复习 MySQL Day1&#xff1a;事务MySQL 事务的四大特性&#xff1f;并发事务会出现什么问题&#xff1f;MySQL 事务的隔离级别&#xff1f;不同事务隔离级别下会发生什么问题&#xff1f;MVCC 的实现原理&#xff1f;核心数据结构版本链构建示例可见性判断算法MVCC 可…

外接键盘与笔记本命令键键位不同解决方案(MacOS)

文章目录 修改键位第一步&#xff1a;打开设置第二步&#xff1a;进入键盘快捷键第三步&#xff1a;修改修饰键设置第四步&#xff1a;调整键位第五步&#xff1a;保存设置tips ikbc c87键盘win键盘没反应的解决亲测的方法这是百度的答案标题常规组合键尝试‌&#xff1a;型号差…

kotlin知识体系(五) :Android 协程全解析,从作用域到异常处理的全面指南

1. 什么是协程 协程(Coroutine)是轻量级的线程&#xff0c;支持挂起和恢复&#xff0c;从而避免阻塞线程。 2. 协程的优势 协程通过结构化并发和简洁的语法&#xff0c;显著提升了异步编程的效率与代码质量。 2.1 资源占用低&#xff08;一个线程可运行多个协程&#xff09;…

vscode stm32 variable uint32_t is not a type name 问题修复

问题 在使用vscodekeil开发stm32程序时&#xff0c;发现有时候vscode的自动补全功能失效&#xff0c;且problem窗口一直在报错。variable “uint32_t” is not a type name uint32_t 定义位置 uint32_t 实际是在D:/Keil_v5/ARM/ARMCC/include/stdint.h中定义的。将D:/Keil_v5…

Formality:Bug记录

相关阅读 Formalityhttps://blog.csdn.net/weixin_45791458/category_12841971.html?spm1001.2014.3001.5482 本文记录博主在使用Synopsys的形式验证工具Formality中遇到的一个Bug。 Bug复现 情况一 // 例1 module dff (input clk, input d_in, output d_out …

【java+Mysql】学生信息管理系统

学生信息管理系统是一种用于管理学生信息的软件系统&#xff0c;旨在提高学校管理效率和服务质量。本课程设计报告旨在介绍设计和实现学生信息管理系统的过程。报告首先分析了系统的需求&#xff0c;包括学生基本信息管理、成绩管理等功能。接着介绍了系统的设计方案&#xff0…