SELECT 语句用法大全:数据库查询的核心力量

在数据库的世界中,SELECT 语句犹如一把万能钥匙,开启了数据检索的大门,让我们能够从海量的数据中精准地获取所需的信息。它的用法丰富多样,涵盖了从简单的数据查看,到复杂的数据统计和关联查询等多个方面,为数据库的有效利用提供了强大的支持。

一、基本查询:开启数据探索之旅

  • 查询所有列:使用 “*” 通配符可以查询表中的所有列,快速了解表的整体数据结构和内容。
    SELECT * FROM employees;
    
  • 查询指定列:指定需要查询的列名,用逗号分隔,聚焦于我们真正关心的数据。
  • SELECT name, age, salary FROM employees;
    

二、条件查询:精准定位目标数据

为了从大量数据中筛选出符合特定条件的数据,WHERE 子句成为了 SELECT 语句的得力助手。通过使用各种比较运算符(如 =、>、<、>=、<=、<>),我们可以构建出精确的条件表达式。

  • 使用比较运算符:通过 WHERE 子句使用比较运算符(如 =、>、<、>=、<=、<>)来筛选满足条件的记录。
    SELECT * FROM employees WHERE age > 30;
    SELECT * FROM employees WHERE salary >= 5000 AND salary <= 8000;
    SELECT * FROM employees WHERE department <> 'IT';
    
  • 使用逻辑运算符:可以使用 AND、OR、NOT 等逻辑运算符组合多个条件。
    SELECT * FROM employees WHERE age > 30 AND department = 'HR';
    SELECT * FROM employees WHERE age < 25 OR salary > 6000;
    SELECT * FROM employees WHERE NOT (department = 'IT');
    
  • 使用 BETWEEN...AND:用于查询某个范围内的值。
    SELECT * FROM employees WHERE salary BETWEEN 4000 AND 6000;
    
  • 使用 IN:用于查询指定值列表中的值。
    SELECT * FROM employees WHERE department IN ('HR', 'Finance');
    
  • 使用 LIKE:用于进行模糊查询,通常与通配符 “%”(代表任意字符序列)和 “_”(代表任意单个字符)一起使用。
    SELECT * FROM employees WHERE name LIKE 'J%';  -- 查询名字以J开头的员工
    SELECT * FROM employees WHERE name LIKE '%s_';  -- 查询名字以s结尾且倒数第二个字符任意的员工
    

三、排序查询:让数据有序呈现

当查询结果需要按照特定的顺序排列时,ORDER BY 子句就发挥了作用。默认情况下,它按照升序(ASC)对数据进行排序;如果需要按照降序排列,只需加上 DESC 关键字,而且,ORDER BY 还可以按照多个列进行排序。

  • 使用 ORDER BY:用于对查询结果按照一个或多个列进行排序,默认是升序(ASC),可以指定降序(DESC)。
    SELECT * FROM employees ORDER BY age ASC;
    SELECT * FROM employees ORDER BY salary DESC, age ASC;  -- 先按照工资降序排序,如果工资相同则按照年龄升序排序
    

四、聚合函数查询:数据统计的利器

聚合函数,在数据分析中起着至关重要的作用,能够快速提供数据的总体特征和趋势。

  • 常用聚合函数:如 COUNT、SUM、AVG、MAX、MIN 等,用于对数据进行统计计算。
    SELECT COUNT(*) FROM employees;  -- 查询员工总数
    SELECT SUM(salary) FROM employees;  -- 查询员工工资总和
    SELECT AVG(salary) FROM employees;  -- 查询员工平均工资
    SELECT MAX(salary) FROM employees;  -- 查询最高工资
    SELECT MIN(salary) FROM employees;  -- 查询最低工资
    
  • 五、分组查询:深入洞察数据分布

  • 分组查询:使用 GROUP BY 子句按照指定列对数据进行分组,然后可以对每组数据进行聚合计算。
    SELECT department, COUNT(*) FROM employees GROUP BY department;  -- 查询每个部门的员工人数
    SELECT department, AVG(salary) FROM employees GROUP BY department HAVING AVG(salary) > 5000;  -- 查询平均工资大于5000的部门及其平均工资
    

六、连接查询:整合多表数据资源

在实际的数据库应用中,往往需要从多个相关的表中获取数据,这时候连接查询就派上了用场。内连接(INNER JOIN)通过共同的列将两个表中的数据关联起来,返回满足连接条件的记录,实现了数据的整合和关联展示。

外连接(包括左外连接 LEFT JOIN、右外连接 RIGHT JOIN 和全外连接 FULL JOIN)则在关联数据的基础上,能够保留一个表中的所有记录,以及另一个表中满足条件的记录,确保了数据的完整性,为数据分析提供了更全面的视角。

内连接:使用 INNER JOIN 关键字,返回两个表中满足连接条件的记录。

SELECT employees.name, departments.department_name
FROM employees
INNER JOIN departments ON employees.department_id = departments.id;

  • 外连接:包括左外连接(LEFT JOIN)、右外连接(RIGHT JOIN)和全外连接(FULL JOIN),可以返回一个表中的所有记录以及另一个表中满足连接条件的记录。
    SELECT employees.name, departments.department_name
    FROM employees
    LEFT JOIN departments ON employees.department_id = departments.id;
    

七、子查询:嵌套查询的智慧

子查询是 SELECT 语句中的一种高级用法,它允许在一个查询中嵌套另一个查询。

  • 作为条件的子查询:子查询可以作为 WHERE 子句中的条件,用于筛选主查询的记录,使得查询条件更加灵活和动态。
    SELECT * FROM employees WHERE salary > (SELECT AVG(salary) FROM employees);
    
  • 作为列的子查询:子查询可以作为主查询中的一列,用于返回一个值或一组值,为数据的呈现增添了更多的信息维度。
    SELECT name, (SELECT MAX(salary) FROM employees) AS max_salary FROM employees;
    

八、分页查询:优化数据展示体验

在处理大量数据时,为了提高查询性能和用户体验,分页查询是一种常用的技巧。通过 LIMIT 关键字,我们可以限制查询结果返回的行数,让用户能够更加便捷地浏览和管理数据。

  • 使用 LIMIT:用于限制查询结果返回的行数,通常用于实现分页功能。
    SELECT * FROM employees LIMIT 10;  -- 返回前10条记录
    SELECT * FROM employees LIMIT 5 OFFSET 10;  -- 返回从第11条记录开始的5条记录

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

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

相关文章

小程序配置文件 —— 14 全局配置 - tabbar配置

全局配置 - tabBar配置 tabBar 字段&#xff1a;定义小程序顶部、底部 tab 栏&#xff0c;用以实现页面之间的快速切换&#xff1b;可以通过 tabBar 配置项指定 tab 栏的表现&#xff0c;以及 tab 切换时显示的对应页面&#xff1b; 在上面图中&#xff0c;标注了一些 tabBar …

计算机网络 (8)物理层的传输方式

一、串行传输与并行传输 串行传输 定义&#xff1a;串行传输是一种数据传输方式&#xff0c;指的是逐位地按照顺序传输数据。在串行传输中&#xff0c;数据位逐个按照一定的顺序进行传输&#xff0c;可以通过单条线路或信道进行。特点&#xff1a; 逐位传输&#xff1a;串行传输…

Edge如何获得纯净的启动界面

启动Edge会出现快速链接&#xff0c;推广链接&#xff0c;网站导航&#xff0c;显示小组件&#xff0c;显示信息提要&#xff0c;背景 ●复杂页面 ●精简页面 点击页面设置按钮 关闭快速链接 关闭网站导航 关闭小组件 关闭信息提要 关闭背景 关闭天气提示 精简页面看起来十分舒…

细说STM32F407单片机CAN基础知识及其HAL驱动程序

目录 一、CAN总线结构和传输协议 1、 CAN总线结构 &#xff08;1&#xff09;闭环结构的CAN总线网络 &#xff08;2&#xff09;开环结构的CAN总线网络 &#xff08;3&#xff09;隐性电平和显性电平 2、CAN总线传输协议 &#xff08;1&#xff09;CAN总线传输特点 &am…

计算机的错误计算(一百九十六)

摘要 用两个大模型计算 arccos(0.444). 结果保留 4位有效数字。两个大模型的计算结果相同&#xff0c;并均有误差。 例1. 计算 arccos(0.444). 结果保留 4位有效数字。 下面是与一个大模型的对话。 以上为与一大模型的对话。 下面是与另一大模型的对话。 点评&#xff1a; &…

打印进度条

文章目录 1.Python语言实现(1)黑白色(2)彩色&#xff1a;蓝色 2.C语言实现(1)黑白颜色(2)彩色版&#xff1a;红绿色 1.Python语言实现 (1)黑白色 import sys import timedef progress_bar(percentage, width50):"""打印进度条:param percentage: 当前进度百分比…

Fiddler断点(拦截)--篡改请求后或者响应前数据

目录 一、断点介绍 图例 简单介绍&#xff1a; 详细介绍&#xff1a; 二、操作步骤 文章操作资源下载 (一)设置要抓包的地址 (二)全局拦截(断点) 1.请求后拦截&#xff08;Before Request&#xff09; 解开拦截 2.响应前拦截&#xff08;After Responses&#xff…

【ArcGIS Pro/GeoScene Pro】可视化时态数据

可视化过去二十年新西兰国际旅游业的发展变化 工程数据下载 ArcGIS Pro 快速入门指南—ArcGIS Pro | 文档 添加数据 数据为中国旅客数据 转置表字段 列数据转行数据

【基础篇】三、MySQL表结构的操作

文章目录 Ⅰ. 创建表1、语法2、创建表样例3、创建和其它表一样结构的表 Ⅱ. 查看表结构1、查看数据库中的表2、查看指定表的属性3、获取表的创建语句 Ⅲ. 删除表Ⅳ. 修改表结构1、向表中插入新的字段2、删除表中的字段3、修改表名4、修改字段属性 Ⅰ. 创建表 1、语法 create …

小程序租赁系统开发的优势与应用探索

内容概要 在如今这个数码科技飞速发展的时代&#xff0c;小程序租赁系统开发仿佛是一张神奇的魔法卡&#xff0c;能让租赁体验变得顺畅如丝。想象一下&#xff0c;无论你需要租用什么&#xff0c;从单车到房屋&#xff0c;甚至是派对用品&#xff0c;只需动动手指&#xff0c;…

ArcGIS教程(009):ArcGIS制作校园3D展示图

文章目录 数据下载校园3D展示图制作创建要素类矢量化【楼】要素矢量化【绿地】矢量化【范围】矢量化处理打开ArcScene添加动画数据下载 https://download.csdn.net/download/WwLK123/90189025校园3D展示图制作 创建要素类 添加底图: 新建【文件地理数据库】,并修改名称为【…

Secured Finance 与 Parasail 在流动性质押领域开展合作

Secured Finance 宣布与 Parasail 达成战略合作&#xff0c;标志着生态在推进 DePIN 及人工智能生态系统能力的重要里程碑。此次合作将 Parasail 卓越的质押方案与 Secured Finance 在去中心化贷款和稳定币协议方面的专业能力相结合&#xff0c;为 Filecoin 生态系统内的创新金…

pytorch基础之注解的使用--003

Title 1.学习目标2.定义3.使用步骤4.结果 1.学习目标 针对源码中出现一些注解的问题&#xff0c;这里专门写一篇文章进行讲解。包括如何自定义注解&#xff0c;以及注意事项&#xff0c;相信JAVA中很多朋友业写过&#xff0c;但是今天写的是Python哦。。。 2.定义 在 Python…

!倒序数 !

时间限制&#xff1a;C/C 1000MS&#xff0c;其他语言 2000MS 内存限制&#xff1a;C/C 256MB&#xff0c;其他语言 512MB 难度&#xff1a;中等 分数&#xff1a;100 OI排行榜得分&#xff1a;12(0.1*分数2*难度) 描述 输入一个非负整数&#xff0c;输出这个数的倒序数。例如…

【Redis】Redis 典型应用 - 缓存 (cache)

目录 1. 什么是缓存 2. 使用 Redis 作为缓存 3. 缓存的更新策略 3.1 定期生成 3.2 实时生成 4. 缓存的淘汰策略 5. 缓存预热, 缓存穿透, 缓存雪崩 和 缓存击穿 关于缓存预热 (Cache preheating) 关于缓存穿透 (Cache penetration) 关于缓存雪崩 (Cache avalanche) 关…

《燕云十六声》d3dcompiler_47.dll缺失怎么解决?

一、d3dcompiler_47.dll缺失的原因 系统更新或升级&#xff1a;Windows系统的更新可能会更改或删除某些旧版本的DirectX组件&#xff0c;包括d3dcompiler_47.dll。游戏安装不完整&#xff1a;游戏安装过程中可能出现中断或错误&#xff0c;导致某些必要的文件未能正确安装。软…

RT-Thread中堆和栈怎么跟单片机内存相联系

现在RT-ThreadMCU的应用方式越来越普遍&#xff0c;RT-Thread需要配置MCU中的RAM到的系统中&#xff0c;进入系统内存管理&#xff0c;才能提供给基于实时系统的应用程序使用&#xff0c;比如给应用程序提供malloc、free等函数调用功能。在嵌入式软件开发中&#xff0c;我们经常…

Qt https请求报错SSL handshake failed 解决思路方法

先执行下面代码 qDebug() << manager.supportedSchemes();bool bSupp QSslSocket::supportsSsl();auto buildVersion QSslSocket::sslLibraryBuildVersionString();QString version QSslSocket::sslLibraryVersionString();qInfo() << bSupp << buildVers…

从CW32L010看HAL库封装方式

原文地址&#xff1a;从CW32L010看HAL库封装方式

锐捷WLAN产品出货量排名第一!

摘要:2024年Q3锐捷WLAN产品出货量排名第一!锐捷多形态Wi-Fi 7产品重磅出击! 近日, IT市场研究和咨询公司IDC发布《IDC中国企业级WLAN市场跟踪报告,2024年Q3》。报告显示,锐捷WLAN产品在2024年Q3出货量位居行业首位。至此,锐捷WLAN产品在2024年的Q1、Q2、Q3均实现了市场出货量的…