SQL— DQL语句学习【后端 11】

DQL语句

请添加图片描述

引言

DQL(Data Query Language,即数据查询语言)是SQL(Structured Query Language)中用于从数据库中检索数据的重要部分。在数据库管理中,DQL语句是日常工作中最常用的工具之一。通过DQL,我们能够从数据库中获取所需的信息,实现数据的精准提取。本文将详细介绍DQL的基础语法,包括基本查询、条件查询、聚合查询、分组查询、排序查询、分页查询等核心内容,并结合具体案例进行说明。


基础语法

SELECT语句

SELECT语句是DQL的核心,用于从数据库表中选取数据,其基本语法如下:

SELECT column1, column2, ...  
FROM table_name;

要查询表中的所有列,可以使用星号(*)作为通配符,表示“选取所有列”:

SELECT *  
FROM table_name;

示例:

假设我们有一个employees表,结构如下:

idnamepositionsalarydepartment
1AliceManager6000HR
2BobAnalyst4000Finance
3CarolEngineer5000IT

查询所有员工信息:

SELECT *  
FROM employees;

查询特定列,如员工姓名和职位:

SELECT name, position  
FROM employees;

WHERE子句

WHERE子句用于筛选满足条件的记录。其基本语法为:

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

条件可以是数值、字符串或日期的比较,也可以通过逻辑运算符(ANDORNOT)组合多个条件。

示例:

查询薪资大于4500的员工信息:

SELECT *  
FROM employees  
WHERE salary > 4500;

查询属于“IT”部门的员工:

SELECT *  
FROM employees  
WHERE department = 'IT';

你还可以组合条件,查询薪资大于4000且职位为“Engineer”的员工:

SELECT *  
FROM employees  
WHERE salary > 4000 AND position = 'Engineer';

基本查询

基本查询是DQL最常见的操作。你只需指定要查询的列和表名即可。

示例:

查询所有学生信息:

SELECT * FROM students;

查询学生的idnameage

SELECT id, name, age FROM students;

条件查询

条件查询通过WHERE子句进行数据过滤,返回满足特定条件的记录。还可以使用INBETWEEN等操作符进行复杂查询。

示例:

查询年龄在18到25岁之间的学生信息:

SELECT *  
FROM students  
WHERE age BETWEEN 18 AND 25;

查询学生所在城市为“New York”或“Los Angeles”的记录:

SELECT *  
FROM students  
WHERE city IN ('New York', 'Los Angeles');

聚合查询

聚合查询通过聚合函数对一组值进行计算,常见的聚合函数包括COUNT()SUM()AVG()MAX()MIN()。这些函数可以帮助你快速获得统计信息。

示例:

查询学生总数:

SELECT COUNT(*)  
FROM students;

计算各城市的学生总数:

SELECT city, COUNT(*)  
FROM students  
GROUP BY city;

查询最高薪资:

SELECT MAX(salary)  
FROM employees;

分组查询

分组查询使用GROUP BY子句,将结果集按一列或多列进行分组。常与聚合函数结合使用,返回每个分组的统计结果。

示例:

按城市分组,查询每个城市的平均学生年龄:

SELECT city, AVG(age) AS avg_age  
FROM students  
GROUP BY city;

分组后可以使用HAVING子句对分组结果进行过滤。例如,查询平均年龄大于20岁的城市:

SELECT city, AVG(age) AS avg_age  
FROM students  
GROUP BY city  
HAVING AVG(age) > 20;

排序查询

ORDER BY子句用于对查询结果按指定列进行排序。可以按升序(ASC)或降序(DESC)排序。

示例:

按年龄升序排列学生信息:

SELECT * FROM students  
ORDER BY age ASC;

按薪资降序排列员工信息:

SELECT * FROM employees  
ORDER BY salary DESC;

你也可以按多列排序,例如,先按部门升序,然后按薪资降序排列:

SELECT *  
FROM employees  
ORDER BY department ASC, salary DESC;

分页查询

分页查询在处理大数据集时尤为重要,避免一次性加载过多数据导致性能问题。在MySQL中,LIMIT子句可以帮助实现分页。

示例:

查询第1页的数据,每页显示5条记录:

SELECT *  
FROM students  
LIMIT 0, 5;

查询第2页的数据,每页显示5条记录:

SELECT *  
FROM students  
LIMIT 5, 5;

如果要查询第n页的数据,可以通过公式(n-1)*每页记录数来确定起始位置。


结论

DQL是数据库查询的核心工具,熟练掌握它能够帮助你从海量数据中高效提取有价值的信息。通过结合基本查询、条件查询、聚合查询、分组查询、排序查询和分页查询,你可以实现对数据的灵活操控。希望本文的讲解和示例能够帮助你更好地理解和运用DQL语句。

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

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

相关文章

三千元左右的卧室投影仪怎么选?当贝D6X Pro代替电视的最佳选择

想象一下,在舒适的卧室中,只需轻轻一瞥,便能享受一场视觉盛宴,无需起身,天花板即成为你的私人影院。这一梦想现已成真,只需挑选一台合适的卧室投影仪,即可实现这一愿望。 下面是2024年卧室投影仪…

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(二)---ROS2与UE5进行图像数据传输

前言 本系列教程旨在使用UE5配置一个具备激光雷达深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博…

C++实现——红黑树

目录 1.红黑树 1.1红黑树的概念 1.2红黑树的性质 1.3红黑树节点的定义 1.4红黑树的插入操作 1.5红黑树的验证 1.6红黑树的删除 1.7红黑树与AVL树的比较 1.8红黑树的应用 1.红黑树 1.1红黑树的概念 红黑树,是一种二叉搜索树,但在每个结点上增加一个存储位…

leetcode67. 二进制求和,简单模拟

leetcode67. 二进制求和 给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。 示例 1: 输入:a “11”, b “1” 输出:“100” 示例 2: 输入:a “1010”, b “1011” 输出:“10101” …

网络如何发送一个数据包

网络如何发送一个数据包 网络消息发送就是点一点屏幕。 骚瑞,这一点都不好笑。(小品就是我的本质惹) 之前我就是会被这个问题搞的不安宁。是怎么知道对方的IP地址的呢?怎么知道对方的MAC呢?世界上计算机有那么多&…

SQL每日一练-0816

今日SQL题:计算每个项目的年度收入增长率 难度系数:🌟☆☆☆☆☆☆☆☆☆ 1、题目要求 计算每个项目每年的收入总额,并计算项目收入环比增长率。找出每年收入增长率最高的项目。输出结果显示年份、项目ID、项目名称、项…

【走迷宫】

题目 DFS代码 #include<bits/stdc.h> using namespace std; const int N 110; int matrix[N][N]; int n, m; int dx[4] {-1, 0, 1, 0}, dy[4] {0, 1, 0, -1}; int dis[N][N]; void dfs(int x, int y, int cnt) {if(cnt > dis[n-1][m-1]) return;if(x n-1 &&a…

[AHK V2] 转换乱码“涓浗”为“中国”

想还原乱码字符串:涓浗 用乱码恢复工具 乱码恢复 可以查看到,该乱码的现在编码是gbk,原来编码是utf8 (也就是说原来是UTF-8编码的字符串,用GBK编码解析导致产生乱码,那么解析思路就是将GBK编码还原成UTF-8即可 ) 编码标识可以在这查阅 代码页标识符 GBK就是cp936 U…

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(一)---UnrealCV获取深度+分割图像

前言 本系列教程旨在使用UE5配置一个具备激光雷达深度摄像机的仿真小车&#xff0c;并使用通过跨平台的方式进行ROS2和UE5仿真的通讯&#xff0c;达到小车自主导航的目的。本教程使用的环境&#xff1a; ubuntu 22.04 ros2 humblewindows11 UE5.4.3python8 本系列教程将涉及以…

解决旧版CMS内容管理无法登录的问题

最近遇到了输入正确的账户密码&#xff0c;旧版的CMS内容管理的平台提示登录成功却无法跳转的问题 遇到这种情况请不要慌&#xff01;&#xff01;&#xff01; 请按照下面的步骤解决问题&#xff1a; 1.点击账号管理 2.点击右上角的返回旧版控制台 3.点击cloud1环境 4.点击扩…

leetcode13. 罗马数字转整数,流程图带你遍历所有情况

leetcode13. 罗马数字转整数 示例 1: 输入: s “III” 输出: 3 示例 2: 输入: s “IV” 输出: 4 示例 3: 输入: s “IX” 输出: 9 示例 4: 输入: s “LVIII” 输出: 58 解释: L 50, V 5, III 3. 示例 5: 输入: s “MCMXCIV” 输出: 1994 解释: M 1000, CM 900, XC…

RK3588J正式发布Ubuntu桌面系统,丝滑又便捷!

本文主要介绍瑞芯微RK3588J的Ubuntu系统桌面演示&#xff0c;开发环境如下&#xff1a; U-Boot&#xff1a;U-Boot-2017.09 Kernel&#xff1a;Linux-5.10.160 Ubuntu&#xff1a;Ubuntu20.04.6 LinuxSDK&#xff1a; rk3588-linux5.10-sdk-[版本号] &#xff08;基于rk3…

Kubectl 常用命令汇总大全

kubectl 是 Kubernetes 自带的客户端&#xff0c;可以用它来直接操作 Kubernetes 集群。 从用户角度来说&#xff0c;kubectl 就是控制 Kubernetes 的驾驶舱&#xff0c;它允许你执行所有可能的 Kubernetes 操作&#xff1b;从技术角度来看&#xff0c;kubectl 就是 Kubernetes…

力扣面试经典算法150题:找出字符串中第一个匹配项的下标

找出字符串中第一个匹配项的下标 今天的题目是力扣面试经典150题中的数组的简单题: 找出字符串中第一个匹配项的下标 题目链接&#xff1a;https://leetcode.cn/problems/find-the-index-of-the-first-occurrence-in-a-string/description/?envTypestudy-plan-v2&envIdto…

知识改变命运 数据结构【栈和队列面试题】

1.最小栈 class MinStack {Stack <Integer>stack;Stack <Integer>minStack; public MinStack() {stacknew Stack<>();minStacknew Stack<>();}public void push(int val) {stack.push(val);if(minStack.empty()) {minStack.push(val);} else {int top…

算法-IMM

trajectory-prediction程序的imm.cc中的以下代码的对应的算法原理在后面 void IMM_UKF::InputInteract() {if (std::isnan(model_pro_(0)) || std::isnan(model_pro_(1)) || std::isnan(model_pro_(2)))std::abort();if (model_pro_.sum() ! 0)model_pro_ / model_pro_.sum();…

Android 12系统源码_多屏幕(二)模拟辅助设备功能开关实现原理

前言 上一篇我们通过为Android系统开启模拟辅助设备功能开关&#xff0c;最终实现了将一个Activity显示到多个屏幕的效果。 本篇文章我们具体来分析一下当我们开启模拟辅助设备功能开关的时候&#xff0c;Android系统做了什么哪些操作。 一、模拟辅助设备功能开关应用位置 …

基于web框架的协同过滤的美食推荐系统【数据爬虫、管理系统、数据可更新、样式可调整】

文章目录 有需要本项目的代码或文档以及全部资源&#xff0c;或者部署调试可以私信博主项目介绍研究背景研究的目的与意义协同过滤算法基于用户的协同过滤算法定义基于物品的协同过滤算法的定义 数据库设计db_food&#xff08;美食信息表&#xff09;db_collect&#xff08;美食…

【Kubernetes】k8s集群图形化管理工具之rancher

目录 一.Rancher概述 1.Rancher简介 2.Rancher与k8s的关系及区别 3.Rancher具有的优势 二.Rancher的安装部署 1.实验准备 2.安装 rancher 3.rancher的浏览器使用 一.Rancher概述 1.Rancher简介 Rancher 是一个开源的企业级多集群 Kubernetes 管理平台&#xff0c;实…

【Linux网络】select函数

欢迎来到 破晓的历程的 博客 ⛺️不负时光&#xff0c;不负己✈️ 文章目录 select函数介绍select函数参数介绍select函数返回值select的工作流程TCP服务器【多路复用版】 select函数介绍 在Linux网络编程中&#xff0c;select 函数是一种非常有用的IO多路复用技术&#xff0…