MySQL3 DQL数据查询语言

news2025/1/18 17:12:09

DQL

    • SQL-DQL
      • 重要地位
      • 简单查询
        • selectjia简单查询
        • 数据准备
        • 别名(AS)
        • 消除重复行(DISTINCT去重)
        • 算数运算符
          • 0.优先级
          • 1.算数运算符
          • 2.比较运算符
          • 3.逻辑运算符
          • 4.位运算符
        • 空值
          • 空值参与运算
      • 条件查询
        • 普通条件查询
        • 特殊比较运算符
        • BETWEEN...AND...
        • IN
        • LIKE
        • IS NULL
        • least,greatest运算符
      • 对查询结果排序
          • 简介:
          • 语法:
          • 排序规则说明
          • 按列名排序
          • 按别名排序
          • 按列序号排序
          • 按多列排序

SQL-DQL

DQL(Data Query Language 数据查询语言)。用途是查询数据库数据,如SELECT语句。是SQL语句中最核心、最重要的语句,也是使用频率最高的语句。其中,可以根据表的结构和关系分为单表查询和多表联查。

单表查询:针对数据库中的一张数据表进行查询,可以通过各 种查询条件和方式去做相关的优化。
多表联查:针对数据库中两张或者两张以上的表同时进行查询, 依赖的手段有复杂查询和嵌套查询。

SELECT   [DISTINCT]
 {*|1.*|[1.字段1 [as  字段别名1]
 [,1.字段2[as  字段别名2]][,]]}
 FROM1 [as  表别名 ]
 [ left|right|inner join  表2   on  表之间
的关系 ]
 [ WHERE]
 [ GROUP BY ] 
[ HAVING]
 [ ORDER BY]
 [ LIMIT  {[ 位置偏移量,]行数}]; 

其中:
“[ ]”包含的内容可以省略;
“{ }”包含的内容必须存在;

必须按照该顺序使用

关键字:

DISTINCT:设定DISTINCT可以去掉重复记录。
AS:表名或者字段名过长时,可以用AS关键字起别名,方便操作。
GROUP BY:按组分类显示查询出的数据。
HAVING:GROUP BY分组时依赖的分组条件。
ORDER BY:将查询出来的结果集按照一定顺序排序完成。
LIMIT:限制显示查询结果的条数。

重要地位

数据库管理系统⼀个重要功能就是数据查询,SQL语句中最核⼼、最重要的语句,也是使⽤频率最 ⾼的语句.数据查询不应只是简单返回数据库中存储的数据,还应该根据需要对数据进⾏筛选以及确定数 据以什么样的格式显示。 MySQL提供了功能强⼤、灵活的语句来实现这些操作。 MySQL数据库使⽤select语句来查询数据。 应⽤

在这里插入图片描述

简单查询

通过简单查询,可以查询表中的所有列或者指定列,通过算术运算符、列别名以及消除重复⾏可以 改变查询结果的显示⽅式。

selectjia简单查询

语法:

select  [all|distinct]
  <目标列的表达式1> AS [别名],
  <目标列的表达式2> AS [别名]...
from <表名1或视图名1> [别名],<表名2或视图名2> [别名]...
[where <条件表达式>]
[group by <列名>]
[having <条件表达式>]
[order by <列名> [asc(从小到大排序)|desc(从大到小排序)]]
[limit <数字或列表>];

简化版查询所有列语法
select * | 列名 from 表 where 条件

说明:

1、 "*" 号代表指定表中的所有列名;  
2、 "|" 代表"或者" 的含义,所以SELECT⼦句后⾯可以既可以写"*" ,也可以写所有的列名,不能两种⽅式都写; 
3、如果使⽤第⼆种⽅式,每个列名之间必须要⽤逗号分隔,最后⼀个列名后⾯不写逗号; 
4、FROM⼦句后⾯写要查询的表名;  
5、SQL语句的最后需要加分号; 
数据准备

创建数据库和表:

CREATE DATABASE db3;
USE db3;
-- 简单查询
-- 创建商品表:
create table product(
 pid int primary key auto_increment, -- 商品编号
 pname varchar(20) not null , -- 商品名字
 price double,  -- 商品价格
 category_id varchar(20) -- 商品所属分类
);

添加数据:

--c001家用电器
insert into product values(null,'海尔洗衣机',5000,'c001');
insert into product values(null,'美的冰箱',3000,'c001');
insert into product values(null,'格力空调',5000,'c001');
insert into product values(null,'九阳电饭煲',200,'c001');
--服饰
insert into product values(null,'啄木鸟衬衣',300,'c002');
insert into product values(null,'恒源祥西裤',800,'c002');
insert into product values(null,'花花公子夹克',440,'c002');
insert into product values(null,'劲霸休闲裤',266,'c002');
insert into product values(null,'海澜之家卫衣',180,'c002');
insert into product values(null,'杰克琼斯运动裤',430,'c002');
 --护肤品
insert into product values(null,'兰蔻面霜',300,'c003');
insert into product values(null,'雅诗兰黛精华水',200,'c003');
insert into product values(null,'香奈儿香水',350,'c003');
insert into product values(null,'SK-II神仙水',350,'c003');
insert into product values(null,'资生堂粉底液',180,'c003');
 --零食
insert into product values(null,'老北京方便面',56,'c004');
insert into product values(null,'良品铺子海带丝',17,'c004');
insert into product values(null,'三只松鼠坚果',88,null);
insert into product values(NULL,'老北京方便面',66,'c004');
INSERT INTO product VALUES(NULL,'老北京方便面',66,'c004');

简单的查询

-- 1.查询所有的商品
select pid,pname,price,category_id from product;
-- 推荐使⽤,可读性⾼
select *  from product;
-- 2.查询商铺名和商品价格
select pname,price from product
别名(AS)

列别名⽤来给查询语句中的列或者表达式重新命名,使语句的可读性更强。

语法:

SELECT   
	列名1 | 表达式1 [as]  [列别名1],
	列名2 | 表达式2  [as]   [列别名2],  
	...,
	列名n | 表达式n  [as]   [列别名n]  
FROM    table;

1.列别名可以直接写在列名或者表达式的后面,也可以添加as关键字,加不加as没有区别,通常不加。

2.如果select子句中有计算表达式,通常使用列别名。

-- 别名 字段名/表名 as(可省略) 别名
SELECT pname AS '商品名',price '价格' FROM product;

注意:

1.列别名中包含有空格

2.列别名中包含有特殊字符,如%,-等。

消除重复行(DISTINCT去重)

重复⾏是查询结果中有完全相同的数据⾏,消除重复⾏是消除相同的查询结果,只保留⼀⾏重复数据,使⽤关键字 DISTINCT 来完成。

语法:

SELECT DISTINCT 列名1,列名2,......列名n FROM 表名;

例如:

-- 去重
-- 去重一列的数据
SELECT DISTINCT category_id FROM product;
-- 去重多列的数据
SELECT DISTINCT price,pname FROM product WHERE pname='老北京方便面' AND price=66;

也可以使⽤DISTINCT关键字消除多列重复数据(同时考虑所有列的数据重复)

算数运算符

简介

数据库中的表结构确⽴后,表中的数据代表的意义就已经确定。通过MySQL运算符进⾏运算,就可 以获取到表结构以外的另⼀种数据。 例如,学⽣表中存在⼀个birth字段,这个字段表示学⽣的出⽣年份。⽽运⽤MySQL的算术运算符⽤ 当前的年份减学⽣出⽣的年份,那么得到的就是这个学⽣的实际年龄数据。

MySQL支持四种运算符:

算数运算符、⽐较运算符、逻辑运算符、位运算符。

0.优先级
乘除优先于加减

相同优先级按照从左至右的顺序依次计算

可以使用括号提升优先级
1.算数运算符

可以在SELECT⼦句中使⽤算术运算符(只对数值型数据起作⽤),来改变查询结果的显示⽅式。其中⽀持的5种运算符包括:

运算符作用
+
-
*
/ 或 DIV除法运算,返回商
% 或 MOD求余运算,返回余数
-- 基本运算
-- 将所有的商品加价10,只是在显示的时候进行操作,表中的数据不进行修改
SELECT pname,price,5*(price+10) AS new FROM product;

SELECT 3+5;
SELECT 3-5;
SELECT 3*5;
SELECT 3/5;
SELECT 3%5;
2.比较运算符
比较运算符说明
=等于
< 和 <=小于和小于等于
> 和 >=大于和大于等于
<=>安全的等于,两个操作码均为NULL时,其所得值为1;而当一个操作码为NULL时,其所得值为0
<> 或 !=不等于
IS NULL 或 ISNULL判断一个只是否为NULL
IS NOT NULL判断一个值是否不为NULL
LEAST当有两个或多个参数时,返回最小值
GREATEST当有两个或多个参数时,返回最大值
BETWEEN…AND…判断一个值是否落在两值之间,包含边界值
IN判断一个值是IN列表中的任意一个值
NOT IN判断一个值不是IN列表中的任意一个值
LIKE通配符匹配
REGEXP正则表达式匹配
3.逻辑运算符
1)按位与运算&:如果左右两边是数字,进行位运算,同为1,则结果为1(应用:a&1==0可判断是否为偶数,a&1==1可判断是否为奇数)2)按位或运算|:有一个为1,则结果为1.3)按位异或^:不同则为1,相同则为0.(应用:异或可进行两数快速交换)
(4)左移<<:每移动一次,该数值扩大为之前的两倍。
(5)右移>>:每移动一次,该数值缩小为之前的一半。
逻辑运算符说明
NOT 或者 !逻辑非
AND 或者 &&逻辑与
OR 或者 ||逻辑或
XOR逻辑异或
4.位运算符

位运算符是在⼆进制数上进⾏计算的运算符。位运算会先将操作数变成⼆进制数,进⾏位运算。然后再 将计算结果从⼆进制数变回⼗进制数。

位运算符说明
|按位或
&按位与
^按位异或
<<按位左移
>>按位右移
~按位取反,反转所有比特
SELECT 3&5;--SELECT 3|5;
SELECT 3^5;-- 异或 不同为1,相同为0
SELECT 3>>5;
SELECT 3<<5;
空值

空值⽤NULL表示,表示⼀种⽆效的、未知的值,空值不是零,也不是空格。

SELECT *  FROM product WHERE pid>15;

查询结果如下:

在这里插入图片描述

空值参与运算

空值参与算术运算,运算后的结果仍为NULL —上述为字符串类型,可以单独修改查看

-- 如果某个值为NULL,NULL不参与运算,结果仍旧为NULL
INSERT INTO product VALUES(NULL,'三只松鼠坚果礼盒',NULL,'c004');
SELECT pname,price,price+10 AS '爪爪' FROM product;
insert into product values(NULL,' 三只松⿏坚果礼盒 ',NULL,'c004'); 
SELECT pid,pname,price+10,category_id FROM product WHERE pname = ' 三只松⿏坚果礼盒 ';

查询结果如下,可以看到空值参与算术运算后,结果仍为空值

在这里插入图片描述

条件查询

通过简单查询,可以查询表中的所有数据⾏。但⼤多数情况下,我们只需要查询符合某些特定条件的数据⾏,这就需要⽤到SQL语⾔中的条件查询来过滤。

普通条件查询

语法:

SELECT [DISTINCT] * | 列名 | 表达式 [别名] [,....]
FROM 表名
[WHERE 条件表达式1  逻辑运算符 条件表达式2];

说明:

1.条件查询使用WHERE子句来完成,WHERE子句必须紧跟在FROM子句后面。

2.条件表达式的格式为:列名 比较运算符 要比较的值,例如:deptno=10

3.常见的比较运算符包括:=、>、>=、<、<=、<>

含义为等于, 大于,大于等于,小于,小于等于,不等于

4.数值型、字符型、日期型数据都可以使用比较运算符进行比较。

5.字符型和日期型数据作为查询条件时,条件表达式右边的值,必须添加单引号

-- 条件查询
-- 1.查询商品价格为200的商品(数值型条件)
SELECT * FROM product WHERE price = 200;

-- 2.查询商品名为老北京方便面(字符型条件)
SELECT * FROM product WHERE pname='老北京方便面';

-- 3.查询商品价格不为200的商品信息(其他条件运算符)
SELECT * FROM product WHERE price != 200;

SELECT * FROM product WHERE price <> 200;

SELECT * FROM product WHERE NOT (price = 200);
-- 4.查询商品价格大于500的商品
SELECT * FROM product WHERE price > 500;

-- 5.查询商品价格在200~3000之间的商品
SELECT * FROM product WHERE price >=200 AND price<= 3000;
SELECT * FROM product WHERE price >=200 && price<= 3000;
特殊比较运算符
BETWEEN…AND…

使⽤BETWEEN … AND… 可以查询出某列的值在某个范围内(包括边界值)的数据⾏。

语法:WHERE 列名 BETWEEN 值1 AND 值2;

-- BETWEEN 200 AND 3000;包含边界值
SELECT * FROM product WHERE price BETWEEN 200 AND 3000;
IN

使⽤IN运算符可以查询出某列的值是否和给定集合内的任意⼀个值相等。

语法:WHERE 列名 IN (值1, 值2, …值n)

-- 6.查询商品价格是200或800的所有商品 in(,,,)
SELECT * FROM product WHERE price = 200 OR price = 800;
SELECT * FROM product WHERE price = 200 || price = 800;
SELECT * FROM product WHERE price IN (200,800);
LIKE

使⽤LIKE运算符可以查询出某列的值是否满⾜关键字匹配,也叫模糊查询。

先介绍两个通配符:

% :⽤来匹配任何字符,进⾏模糊匹配

_ : 下划线_⽤来匹配单个字符

-- 7.like %占位符 占多位 _占位符 占一位
-- 以老字开头的
SELECT * FROM product WHERE pname LIKE '老%';
-- 以水字结尾的
SELECT * FROM product WHERE pname LIKE '%水';
-- 商品中第三个字为京字的商品
SELECT * FROM product WHERE pname LIKE '__京%';
-- 商品中包含老字的商品
SELECT * FROM product WHERE pname LIKE '%老%';
IS NULL

如果要查询某列的值是否为NULL,

使⽤ “ 列名 = NULL” 是查询不出来的。只能使⽤ “ 列名 IS NULL”

-- 8.is null 运算符
-- null和null不等,不能拿来判断
SELECT * FROM product WHERE category_id = NULL;
SELECT * FROM product WHERE category_id IS NULL;
SELECT * FROM product WHERE category_id IS NOT NULL;
least,greatest运算符
-- 9.最大值,最小值
SELECT LEAST(10,20,30);
-- 如果求最小值时有null,则直接返回null
SELECT LEAST(10,20,NULL) MIN;

SELECT GREATEST(10,20,30);
-- 如果求最大值时有null,则直接返回null
SELECT GREATEST(10,20,NULL);

SELECT LEAST(pid,price),pname FROM product;

对查询结果排序

简介:

前⾯讲解的简单查询和条件查询SQL,结果集的显示顺序都不是我们指定的。在⼤多数情况下,我 们希望查询出来的结果集按照⼀定的顺序显示,⽐如按价格降序显示、在价格基础上分类排序等等。这就需要⽤到SQL语⾔中的对结果集排序的⼦句ORDER BY。

语法:
 SELECT   字段名 1 ,字段名 2 , …… 
 FROM     表名 
 [WHERE   条件 ] 
 [ORDER BY  字段名 1 [ASC|DESC], 字段名 2[ASC|DESC]];
排序规则说明

1、ORDER BY⽤于⼦句中可以⽀持单个字段,多个字段,表达式,函数,别名等

2、可以按照3种⽅式进⾏排序:分别是按列名排序、按列别名排序、按列序号排序。

3、ASC表示按升序排序(默认值), DESC表示按降序排序。

-- OrderBy子句
USE db3;
-- ASC升序
SELECT * 
FROM product
ORDER BY price ASC;
-- DESC降序
SELECT * 
FROM product
ORDER BY price DESC;

4、可以同时按照多个列名进⾏排序

5、ORDER BY ⼦句必须写在SELECT语句的最后,LIMIT⼦句除外

6、数字升序排列⼩值在前,⼤值在后。即按照数字⼤⼩顺序由⼩到⼤排列。

7、⽇期升序排列相对较早的⽇期在前,较晚的⽇期在后。

8、字符升序排列按照字⺟由⼩到⼤的顺序排列,即由A-Z排列。

9、空值在升序排列中排在最前⾯,在降序排列中排在最后。

按列名排序
-- 进行排序,按照商品的价格来排序
-- 降序
SELECT *
FROM product
WHERE category_id IN('c001','c002')
ORDER BY price DESC;

-- 默认升序ASC 可写可不写
SELECT *,price*100 AS `猫猫`
FROM product
ORDER BY 5 ASC;
按别名排序
-- 按照别名排序
SELECT *,price*100 AS 猫猫
FROM product
ORDER BY 猫猫 DESC;
按列序号排序
-- 按照列的序号来进行排序,表的第几列
SELECT *
FROM product
ORDER BY 4;
按多列排序
-- 先按照价格降序排序,价格相同按照pid排序
SELECT * 
FROM product
ORDER BY price DESC,pid ASC;

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

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

相关文章

Unity补完计划 之 SpriteEditer SingleMode

本文仅作笔记学习和分享&#xff0c;不用做任何商业用途 本文包括但不限于unity官方手册&#xff0c;unity唐老狮等教程知识&#xff0c;如有不足还请斧正 因为unity不只是3d需要&#xff0c;还有2d游戏需要大量编辑处理图片素材&#xff0c;所以需要了解Sprite&#xff08;精灵…

ASC格式的协议数据解析

函数来自RTT的AT组件 - at_client.c 例如&#xff0c;数据是 CGREG: 0,1&#xff0c;通过at_resp_parse_line_args_by_kw把1赋予link_stat。 简化从AT响应中提取信息的过程&#xff0c;使得编写与硬件通信的代码更加简洁和易于维护。 这么提数据也太方便了 at_resp_parse_l…

结构体练习作业

作业一:结构体数组存储学生信息(姓名&#xff0c;年龄&#xff0c;分数)&#xff0c;完成输入学生信息&#xff0c;输出学生信息&#xff0c;求学生成绩之和&#xff0c;求最低学生成绩。 .h文件 main.c .c文件 输入信息 输出信息 平均值 最低值 作业二:在堆区&#xff0c;申…

STC-ISP升级MCU

STC-ISP升级mcu步骤&#xff1a; 1、RS232线连接电脑&#xff0c;芯片型号选择STC8H8K64U 2、波特率选择115200 3、IRC频率选择24MHz 4、设置EEPROM大小为64K 如下图设置&#xff1a; 插上RS232选择相应的COM口&#xff1a; 我这里的COM口是COM5. 打开程序文件&#xff1…

揭秘Redis的“隐藏武器”:跳跃表的原理与应用

1. 引言 1.1 Redis的快速崛起 Redis&#xff0c;全名为Remote Dictionary Server&#xff0c;是一个开源的高性能键值对存储系统&#xff0c;它提供了多种类型的数据结构&#xff0c;如字符串、列表、集合、有序集合等。由于其高性能、持久化选项以及丰富的特性&#xff0c;Re…

【已解决】如何获取到DF数据里最新的调薪时间,就是薪资最高且时间最早?

问题说明&#xff1a; 前几天在Python最强王者交流群【群除我佬】问了一个Pandas处理的问题&#xff0c;这里拿出来给大家分享下。 看上去不太好理解&#xff0c;其实说白了&#xff0c;就是在工资最高里&#xff0c;再找时间最早的。 换句话说就是&#xff0c;这三个人&…

益九未来CEO曾宪军:创新引领,打造智能售货机行业新标杆

在智能零售行业迅速发展的今天&#xff0c;益九未来&#xff08;天津&#xff09;科技发展有限公司正以其创新精神和前瞻性的战略布局&#xff0c;引领着智能售货机市场的潮流。而这一切的背后&#xff0c;离不开总经理&#xff08;CEO&#xff09;曾宪军先生的卓越领导和远见卓…

人类预期寿命数据-1960至2022年(世界各国与中国各省)

数据简介&#xff1a;人类预期寿命是指在特定年龄出生的人群&#xff0c;按照当前的死亡率水平&#xff0c;预期平均能够存活的年数。预期寿命衡量一个国家和地区卫生健康状况、社会经济发展水平和生活条件的重要参数&#xff0c;这次数据包含世界各国&#xff08;1960-2022年&…

代理IP类型详细解析:那么多种协议的代理如何选?

代理IP已经成为跨境业务的得力工具&#xff0c;但是仍有许多新手小白在初次接触到代理IP服务商时&#xff0c;不知道具体如何选择代理IP类型&#xff0c;面对五花八门的代理类型名称&#xff0c;往往需要付出一定的试错成本才知道哪个适合自己的业务。今天就来给大家科普科普&a…

深度学习中的规范化-层规范化

文章目录 层规范化层规范化参数与公式normalized_shape传入一个整数接口函数LayerNorm计算手动计算 normalized_shape传入一个列表接口函数LayerNorm计算手动计算 层规范化 在批量规范化这篇文章里详细介绍了批量规范化在卷积神经网络里的使用&#xff0c;本篇文章将继续介绍另…

LVS中NAT模式和DR模式实战讲解

1DR模式 DR&#xff1a;Direct Routing&#xff0c;直接路由&#xff0c;LVS默认模式,应用最广泛,通过为请求报文重新封装一个MAC首部进行 转发&#xff0c;源MAC是DIP所在的接口的MAC&#xff0c;目标MAC是某挑选出的RS的RIP所在接口的MAC地址&#xff1b;源 IP/PORT&#xf…

C++:auto关键字、内联函数、引用、带默认形参值的函数、函数重载

一、auto关键字 在C中&#xff0c;auto关键字是一个类型说明符&#xff0c;用于自动类型推导。 使用 auto 关键字时&#xff0c;变量的类型 是在编译时由编译器 根据 初始化表达式 自动推导出来的。这意味着你 不能在 声明 auto 变量时 不进行初始化 声明 auto 变量时&#x…

“八股文”:是助力还是阻力?

在程序员面试中&#xff0c;“八股文”是一个绕不开的话题。所谓“八股文”&#xff0c;指的是那些在面试中经常出现的标准问题及其答案&#xff0c;例如“解释一下死锁的概念”、“CAP理论是什么”等。这些内容通常被求职者反复练习&#xff0c;以至于变成了某种固定的模式或套…

分享6类10种政务AI大模型应用场景

大模型是指具有大规模参数和复杂计算结构的机器学习模型。这些模型通常由深度神经网络构建而成&#xff0c;拥有数十亿甚至数千亿个参数。大模型的设计目的是提高模型的表达能力和预测性能&#xff0c;能够处理更加复杂的任务和数据。大模型在各种领域都有广泛的应用&#xff0…

adword — Recho | pwn题目记录

涉及到以前没接触过的点&#xff0c;记录下。 checksec&#xff1a; IDA&#xff1a; 很明显的一个栈溢出&#xff0c;但是一直有一个while循环&#xff0c;就算劫持控制流后也出不了这个循环。这里学到了一个新方法&#xff1a; pwntools的shutdown(send) def shutdown(…

C++现代教程四

float转string不带多余0 float a 1.2; std::tostring(a); // 1.200000 std::ostringstream strStream; strStream << a; // 1.2 if (!strStream.view().empty()) // 判定流有数据// 边框融合 float measureText(std::u8string text, FontTypes::Rectangle &recta…

Marin说PCB之1000-BASE-T1上的共模电感的选型知多少---02

今天刚刚好是立秋的第一天&#xff0c;天气还是有点炎热的。不知道诸位老铁们有没有买今年秋天的第一杯奶茶&#xff0c;反正小编我是下班到家吃饭的时候买了一杯伯牙绝弦&#xff0c;喝起来味道还是不错的&#xff0c;而且奶茶店里今天几乎爆满&#xff0c;我足足等了30分钟才…

计算机网络面试-核心概念-问题理解

目录 1.计算机网络OSI协议七层结构功能分别是什么&#xff1f;如何理解这些功能 2.物理层、数据链路层、网络层、传输层和应用层&#xff0c;这五个层之间功能的关系&#xff0c;或者说是否存在协调关系 3. 数据链路层功能理解 4.MAC地址和以太网协议 5.以太网协议中的CSMA…

第十八节、野猪撞墙判定和等候计时

一、野猪撞墙修改 1、判断地面 2、检测半径迁移至头部 3、设置前后的监测点 二、自动调整检测半径 玩家的检测半径实现自动调整 bounds 是正常世界窗口的碰触体外框 这一章节很复杂观看代码physicalcheck和enemy