写了6年SQL,推荐快速上手MySQL 的SQL语句

写了6、7年SQL,有写复杂,有写简单,但总体而言,基础是统一的,。就像编程之需要会加减乘除,用MySQL懂这些SQL就足够了。

目录

      • 1. SELECT 查询
      • 2. WHERE 子句
      • 3. ORDER BY 子句
      • 4. GROUP BY 子句
      • 5. HAVING 子句
      • 6. JOIN 查询
      • 7. 子查询
      • 8. INSERT INTO 查询
      • 9. UPDATE 查询
      • 10. DELETE 查询
      • 11. LIMIT 子句
      • 12. DISTINCT 关键字

MySQL 查询语句是用于从数据库中检索数据的语句。以下是一些常见的 MySQL 查询语句,并附详细说明和示例:

1. SELECT 查询

image.png

基本查询

SELECT column1, column2, ...
FROM table_name;

示例:

SELECT first_name, last_name
FROM employees;

employees 表中选择 first_namelast_name 字段。

image.png

查询所有列

SELECT *
FROM table_name;

示例:

SELECT *
FROM employees;

employees 表中选择所有列。

带条件的查询

SELECT column1, column2, ...
FROM table_name
WHERE condition;

示例:

SELECT first_name, last_name
FROM employees
WHERE department = 'Sales';

employees 表中选择 Sales 部门的 first_namelast_name 字段。

2. WHERE 子句

使用 ANDOR 逻辑运算符

SELECT column1, column2, ...
FROM table_name
WHERE condition1 AND condition2 OR condition3;

示例:

SELECT first_name, last_name
FROM employees
WHERE department = 'Sales' AND salary > 50000;

employees 表中选择 Sales 部门且薪水大于 50000 的员工的 first_namelast_name 字段。

3. ORDER BY 子句

按指定列排序

SELECT column1, column2, ...
FROM table_name
ORDER BY column1 ASC|DESC, column2 ASC|DESC, ...;

示例:

SELECT first_name, last_name
FROM employees
ORDER BY last_name ASC, first_name DESC;

last_name 升序和 first_name 降序排列 employees 表中的数据。

4. GROUP BY 子句

按指定列分组并聚合数据

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

示例:

SELECT department, COUNT(*)
FROM employees
GROUP BY department;

department 列对 employees 表中的数据进行分组,并计算每个部门的员工数量。

5. HAVING 子句

对分组后的结果进行过滤

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

示例:

SELECT department, COUNT(*)
FROM employees
GROUP BY department
HAVING COUNT(*) > 5;

筛选出员工数量大于 5 的部门。
image.png

6. JOIN 查询

内连接

SELECT columns
FROM table1
INNER JOIN

table2
ON table1.column = table2.column;

示例:

SELECT employees.first_name, employees.last_name, departments.department_name
FROM employees
INNER JOIN departments
ON employees.department_id = departments.department_id;

employees 表和 departments 表进行内连接,选择 first_namelast_namedepartment_name

左连接

SELECT columns
FROM table1
LEFT JOIN table2
ON table1.column = table2.column;

示例:

SELECT employees.first_name, employees.last_name, departments.department_name
FROM employees
LEFT JOIN departments
ON employees.department_id = departments.department_id;

employees 表中选择所有记录,并匹配 departments 表中的记录,如果没有匹配到则返回 NULL。

右连接

SELECT columns
FROM table1
RIGHT JOIN table2
ON table1.column = table2.column;

示例:

SELECT employees.first_name, employees.last_name, departments.department_name
FROM employees
RIGHT JOIN departments
ON employees.department_id = departments.department_id;

departments 表中选择所有记录,并匹配 employees 表中的记录,如果没有匹配到则返回 NULL。

7. 子查询

在 SELECT 中使用子查询

SELECT column1
FROM table_name
WHERE column2 = (SELECT column
                 FROM another_table
                 WHERE condition);

示例:

SELECT first_name, last_name
FROM employees
WHERE department_id = (SELECT department_id
                       FROM departments
                       WHERE department_name = 'Sales');

employees 表中选择 Sales 部门的所有员工。

在 FROM 子句中使用子查询

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

示例:

SELECT sub.first_name, sub.last_name
FROM (SELECT first_name, last_name
      FROM employees
      WHERE department_id = 1) AS sub;

从子查询结果中选择 department_id 为 1 的员工的 first_namelast_name

8. INSERT INTO 查询

插入数据

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

示例:

INSERT INTO employees (first_name, last_name, department_id, salary)
VALUES ('John', 'Doe', 3, 50000);

employees 表中插入一条新记录。

9. UPDATE 查询

更新数据

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

示例:

UPDATE employees
SET salary = 55000
WHERE last_name = 'Doe';

更新 last_name 为 ‘Doe’ 的员工的 salary 为 55000。

10. DELETE 查询

删除数据

DELETE FROM table_name
WHERE condition;

示例:

DELETE FROM employees
WHERE last_name = 'Doe';

删除 last_name 为 ‘Doe’ 的员工记录。

11. LIMIT 子句

限制结果集

SELECT column1, column2, ...
FROM table_name
LIMIT number;

示例:

SELECT first_name, last_name
FROM employees
LIMIT 10;

选择前 10 条员工记录。

12. DISTINCT 关键字

去重查询

SELECT DISTINCT column1, column2, ...
FROM table_name;

示例:

SELECT DISTINCT department_id
FROM employees;

选择 employees 表中所有不同的 department_id

这些示例涵盖了 MySQL 中的基本查询语句及其常见用法。通过这些示例,你可以构建更复杂的查询来满足不同的数据检索需求。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

免费代理为什么不适合您的业务需求?

在数字时代,网络已经成为人们日常生活和商业活动中不可或缺的一部分。为了实现更广阔的业务拓展和更畅通的网络体验,许多人开始考虑使用代理服务器。然而,虽然免费代理可能听起来像是个经济实惠的选择,但事实上,它可能…

微服务开发与实战Day06 - MQ基础篇

一、MQ 高性能的异步通讯组件 课程背景 同步通讯:并发能力弱 异步通讯:并发能力强 1. 初始MQ 1.1 同步调用 以黑马商城的余额支付为例: (1)同步调用的优势是什么? 时效性强,等待到结果后才…

基于SSD的安全帽检测

目录 1. 作者介绍2. SSD算法介绍2.1 SSD算法网络结构2.2 SSD算法训练过程2.3 SSD算法优缺点 3. 基于SSD的安全帽检测实验3.1 VOC 2007安全帽数据集3.2 SSD网络架构3.3 训练和验证所需的2007_train.txt和2007_val.txt文件生成3.4 模型训练3.5 GUI界面3.6 结果展示3.7 文件下载 4…

【Unity+AI01】在Unity中调用DeepSeek大模型!实现AI对话功能!

要在Unity中调用DeepSeek的API并实现用户输入文本后返回对话的功能,你需要遵循以下步骤: 获取API密钥: 首先,你需要从DeepSeek获取API密钥。这通常涉及到注册账户,并可能需要订阅相应的服务。 集成HTTP请求库&#xf…

基于python多光谱遥感数据处理、图像分类、定量评估及机器学习

原文链接:基于python多光谱遥感数据处理、图像分类、定量评估及机器学习 普通数码相机记录了红、绿、蓝三种波长的光,多光谱成像技术除了记录这三种波长光之外,还可以记录其他波长(例如:近红外、热红外等)光…

pytorch神经网络训练(AlexNet)

导包 import osimport torchimport torch.nn as nnimport torch.optim as optimfrom torch.utils.data import Dataset, DataLoaderfrom PIL import Imagefrom torchvision import models, transforms 定义自定义图像数据集 class CustomImageDataset(Dataset): 定义一个自…

Ubuntu22.04 下 pybind11 搭建,示例

Pybind11 是一个轻量级的库,用于在 C 中创建 Python 绑定。Ubuntu22下安装pybind11步骤如下: 1. 安装 pybind11 1.1 pip 命令安装 pip3 install pybind11 1.2 源代码安装 安装依赖库: sudo pip install -i https://pypi.tuna.tsinghua.e…

AVR晶体管测试仪开源项目编译

AVR晶体管测试仪开源项目编译 📍原项目地址:https://github.com/Mikrocontroller-net/transistortester/tree/master🌿 https://github.com/svn2github/transistortester🌿 https://github.com/wagiminator/ATmega-Transistor-Tes…

2. Revit API UI 之 IExternalCommand 和 IExternalApplication

2. Revit API UI 之 IExternalCommand 和 IExternalApplication 上一篇我们大致看了下 RevitAPI 的一级命名空间划分,再简单讲了一下Attributes命名空间下的3个类,并从一个代码样例,提到了Attributes和IExternalCommand ,前者是指…

vite配置unocss

在vue3vitetseslintprettierstylelinthuskylint-stagedcommitlintcommitizencz-git介绍了关于vitevue工程化搭建,现在在这个基础上,我们增加一下unocss unocss官方文档 具体开发中使用遇到的问题可以参考不喜欢原子化CSS得我,还是在新项目中使…

NumPy和数组

1.NumPy是什么 NumPy(Numerical Python的缩写)是一个开源的Python科学计算模块,其中包含了许多实用的数学函数,用来处理数值型数据。NumPy中,最重要和使用最频繁的对象就是N维数组。 为什么要学习NumPy? …

Java高级技术探索:深入理解JVM内存分区与GC机制

文章目录 引言JVM内存分区概览垃圾回收机制(GC)GC算法基础常见垃圾回收器ParNew /Serial old 收集器运行示意图 优化实践结语 引言 Java作为一门广泛应用于企业级开发的编程语言,其背后的Java虚拟机(JVM)扮演着至关重…

TikTok Ads广告综合指南:竞价策略及效果建议

作为全球最受欢迎的应用程序之一,TikTok不仅为用户提供了记录分享生活中美好时刻、交流全球创意的平台,也给全球的企业提供了一个直接触达用户的平台。随着Z时代用户人群的购买力不断上升,出海广告主们也逐渐将目光放在TikTok方面的营销。 上…

【Linux系统编程】线程

Linux线程 文章目录 Linux线程1.进程与线程区别2.线程优点3.API概要4.线程1.线程的创建2.线程等待内存共享验证3.线程退出关于对void** &的理解拓展 4.互斥锁1.创建及销毁互斥锁2.加锁及解锁 5.什么情况下会造成死锁6.条件**1. 创建及销毁条件变量****2. 等待****3. 触发**…

基于大数据的主流电商平台获取商品详情数据SKU数据价格数据

主流电商平台:淘宝 1688 闲鱼 京东 唯品会 蘑菇街 一号店 阿里妈妈 阿里巴巴 苏宁 亚马逊 易贝 速卖通 电子元件 网易考拉 洋码头 VVIC MIC Lazada 拼多多 ​ ​​​​​​​关于电商大数据的介绍: 主流电商大数据的采集:电商API接口的接入…

潮玩宇宙大逃杀APP系统开发成品案例分享指南

这是一款多人游戏,玩家需要选择一个房间躲避杀手。满足人数后,杀手会随机挑选一个房间杀掉里面所有的参与者,其他房间的幸存者将平均瓜分被杀房间的元宝。玩家在选中房间后,倒计时结束前可以自由切换不同房间。 软件项目开发成品…

【Linux】进程控制3——进程程序替换

一,前言 创建子进程的目的之一就是为了代劳父进程执行父进程的部分代码,也就是说本质上来说父子进程都是执行的同一个代码段的数据,在子进程修改数据的时候进行写时拷贝修改数据段的部分数据。 但是还有一个目的——将子进程在运行时指向一个…

自动控制原理【期末复习】(二)

无人机上桨之后可以在调试架上先调试: 1.根轨迹的绘制 /// 前面针对的是时域分析,下面针对频域分析: 2.波特图 3.奈维斯特图绘制 1.奈氏稳定判据 2.对数稳定判据 3.相位裕度和幅值裕度

JavaScript的数组排序

天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。…

Sora和快手可灵背后的核心技术 | 3DVAE:通过小批量特征交换实现身体和面部的三维形状变分自动编码器

【摘要】学习3D脸部和身体生成模型中一个解开的、可解释的和结构化的潜在表示仍然是一个开放的问题。当需要控制身份特征时,这个问题尤其突出。在本文中,论文提出了一种直观而有效的自监督方法来训练一个3D形状变分自动编码器(VAE),以鼓励身份特征的解开潜在表示。通过交换不同…