数据库(mysql)-基本查询语句(DQL)

查询语句

这边查询是给予一定表格,这边先做个解释

教师表包括(name(姓名),gender(性别),salary(工资),title(职位),subject_id(课程的编号),comm(奖金))

学生表包括(姓名(name),gender(性别),job(职位),生日(birth))

模版

SELECT 字段名 FROM 查询表 WHERE 查询语句

或与非

AND 查询语句条件必须同时满足才能返回true,      满足true就返回查询相应的值

OR 查询语句条件只要满足其一就返回true,            满足true就返回查询相应的值

NOT 与查询条件相反就返回true,                             满足true就返回查询相应的值

 实例

#查看工资高于5000的女老师都有谁?
SELECT name,age,gender,salary
FROM teacher
WHERE salary>5000 AND gender='女'; #查看工资高于5000的男老师或所有女老师的工资?
SELECT name,gender,salary
FROM teacher
WHERE salary>5000 AND gender='男'
OR gender='女';
6.查看工资在4000到8000以外的老师及具体工资?
SELECT name,salary
FROM teacher
WHERE salary NOT BETWEEN 4000 AND 8000;

需要注意是或与且具有优先级,AND级别比OR级别高,会优先执行AND的代码

用于在一个范围内筛选值(一般数字范围,含头含尾)

BETWEEN  最小值 AND 最大值 

实例 

#查看工资在4000到8000以外的老师及具体工资?
SELECT name,salary
FROM teacher
WHERE salary NOT BETWEEN 4000 AND 8000;

指定多个可能的值来过滤结果集

IN(value1,value2,...) 多个值有,分割

#查看一级讲师和二级讲师的奖金(comm)是多少?
SELECT name,comm
FROM teacher
WHERE title IN ('一级讲师','二级讲师');

用于从结果集中删除重复的行

SELECT  DINSTINCT 字段名 FROM 查询表名

#查看所有女老师的职称都是什么?
SELECT DISTINCT title
FROM teacher
WHERE gender='女';

模糊查询

LIKE 关键字 ,用于在 WHERE 子句中搜索列中的指定模式

通配符

 % :匹配0,1个 多个字符

_  :  匹配单一字符

#举例
1.某字段后模糊查询
# 查询名字姓"李"的学生姓名SELECT name,gender,ageFROM studentWHERE name LIKE '李%';
2.某字段前模糊查询
# 查询名字以"郭"结尾的学生姓名SELECT name,age,genderFROM studentWHERE name LIKE '%郭';
3.包含某字符的模糊查询
# 查询名字中包含"江"的学生姓名SELECT name,age,genderFROM studentWHERE name LIKE '%江%';
_ 举例
1.一个_模糊匹配
# 查询名字第二个字是"苗"的学生信息SELECT name,age,genderFROM studentWHERE name LIKE '_苗%';
2. 多个_模糊匹配
#查询名字中第3个字是'杰'的学生信息SELECT name,age,genderFROM studentWHERE name LIKE '__杰%' ; 

NULL值判断

区别  NULL是一种状态 不是数值 和 java中定义的不一样

IS  是一个比较操作符,它主要用于与NULL 值进行比较

因为标准的比较操作符(如 =<> 等)不能用于 NULL 值,所以需要使用 IS或 IS NOT 来检查 NULL 值

实例

1.查询某字段状态为null
#查询奖金为null的老师
SELECT name, comm FROM teacher WHERE comm IS NULL;
2.查询某字段状态不为为null
#查询奖金为null的老师
SELECT name, comm FROM teacher WHERE comm IS NOT NULL;

 排序

 ORDER BY  用于对查询结果集中的记录进行排序,默认升序

 实例

1.升序
#查看老师的奖金排名,奖金由少到多(默认升序)
SELECT name, comm FROM teacher ORDER BY comm ASC(可写可不写);
2.降序
#查看老师的奖金排名,奖金由少到多(默认升序)
SELECT name, comm FROM teacher ORDER BY comm DESC(必须写);

 这边用学生表举例

特殊情况 日期排列 (远小近大) 是以现在时间为判断基准

#查看学生的生日,按照远小近大的升序(年龄由大到小)
SELECT name,birth From student ORDER BY birth ;
#查看学生的生日,按照远小近大的升序(年龄由小到大)
SELECT name,birth From student ORDER BY birth DESC;

 多字段排序

ORDER BY 字段名1,字段名2...  

优先结果集以第一个字段排序,当第一个字段有重复的值就以第二个字段排序,依次类推

当一个字段排序没有重复的值,不会用第二个字段排序

 实例

#查看老师的奖金和工资 首先按照奖金升序,再以工资降序
SELECT comm,salary From teacher ORDER BY comm,salary DESC;

注意的是null是状态,它可能是无限大或者无限小,这边是无限小 

 分页

运用了大量数据,电商产品

分页是查询的方言,不同数据库sql写法不同

这边以mariadb和mysql举例

SELECT 字段名

FROM 查询表格

WHERE 查询语句

ORDER BY 字段

LIMIT M,N 用于分页查询 

M:跳过结果集中多少条记录

N:从跳过的记录后开始检索出多少条记录

 实例

#查询老师奖金前5名
M :(1-1)*5 这边指的是跳过条目 这边要看前5名,不需要跳过
N:5 显示条目
SELECT name,salary FROM teacher ORDER BY salary DESC LIMIT 0,5;
#查询老师奖金6-10名
M :(2-1)*5=5 这边指的是跳过条目 这边要跳过前5名,5/5是一页,在原本第2页要现在放置到第一页
N:5
SELECT name,salary FROM teacher ORDER BY salary DESC LIMIT 5,5;
#查询老师奖金10-15名
M : 跳过9条,
N: 6  15-10+1=6
SELECT name,salary FROM teacher ORDER BY salary DESC LIMIT 9,6;
#查询老师奖金信息 按照降序排,每页显示3条,显示5页
M:(5-1)*3=12; 这边指的是页数
N:5
SELECT name ,comm FROM teacher ORDER BY comm DESC LIMIT 12,3;

使用表达式 

#查看老师的年薪和月薪
SELECT name ,salary,salary*12 FROM teacher;
#薪资没有空值null

 空值函数

IFNULL(arg1,arg2) 如果arg1不为null,返回arg1,否则返回arg2

#NULL值是状态不能进行计算,这边使用IFNULL,当comm为null替换成0
#查看老师的奖金和薪资的总和
SELECT name, salary,comm ,salary+IFNULL(comm,0) FROM teacher;
#查看老师的奖金和全年的奖金
SELECT name, salary,comm ,IFNULL(comm,0)*12 FROM teacher;

 别名

字段名 AS '别名' 

实例都行 

#字段别名(不写 AS)
SELECT name,salary,salary*12 annusal FROM teacher;
#字段别名(别名单引号)
SELECT name,salary,salary*12 'annusal' FROM teacher;
#字段别名(别名单引号加AS)
SELECT name,salary,salary*12 AS 'annusal' FROM teacher;
#字段别名(别名双引号加AS)
SELECT name,salary,salary*12 "annusal" FROM teacher;
#字段别名(别名双引号加AS)
SELECT name,salary,salary*12 AS "annusal" FROM teacher;

 运行图

 特殊情况 

数据库有关键字或者别名中有空格: 必须加单引号或者写双引号

//这边必须写单引号或者双引号
SELECT name,salary,salary*12 AS "annusal unlock" FROM teacher;
//这边必须写单引号或者双引号
SELECT name,salary,salary*12 AS "FORM" FROM teacher;
不写报语法结构错误

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

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

相关文章

k8s_入门_命令详解

命令详解 kubectl是官方的CLI命令行工具&#xff0c;用于与 apiserver进行通信&#xff0c;将用户在命令行输入的命令&#xff0c;组织并转化为 apiserver能识别的信息&#xff0c;进而实现管理k8s各种资源的一种有效途径 1. 帮助 2. 查看版本信息 3. 查看资源对象等 查看No…

Linux应用开发(3):Linux时间操作(time、mktime、localtime等)

1. 简述 在Linux系统中&#xff0c;时间操作函数是编程中经常使用的一部分&#xff0c;它们允许程序获取和设置系统时间&#xff0c;以及对时间进行各种处理。以下是一些常用的时间操作函数的详细介绍。 2. 时间操作 &#xff08;1&#xff09;time(): 获取1970年1月1日以来的…

爬虫入门教程(一)

爬虫入门教程 1.什么是爬虫 爬虫是一种自动获取网站数据的程序或脚本。它可以自动模拟人类访问网站,获取网页源代码,解析并提取出所需的数据。 爬虫的工作原理类似于搜索引擎的索引程序&#xff0c;它们会按照预定的规则和算法在互联网上不断地爬取网页&#xff0c;收集信息…

k8s知识

k8s是用于容器编排和管理的&#xff0c;docker或者ctr是k8s的运行时&#xff0c;k8s通过容器运行时来启动容器&#xff0c;容器启动需要镜像&#xff0c;镜像可以用docker构建&#xff0c;dockerfile就是用于自定义如何构建镜像&#xff0c;所以上面那套流水线就是先用dockerfi…

Linux|从 STDIN 读取 Awk 输入

简介 在之前关于 Awk 工具的系列文章中&#xff0c;主要探讨了如何从文件中读取数据。但如果你希望从标准输入&#xff08;STDIN&#xff09;中读取数据&#xff0c;又该如何操作呢&#xff1f; 在本文中&#xff0c;将介绍几个示例&#xff0c;展示如何使用 Awk 来过滤其他命令…

即插即用篇 | YOLOv8引入Haar小波下采样 | 一种简单而有效的语义分割下采样模块

本改进已集成到 YOLOv8-Magic 框架。 下采样操作如最大池化或步幅卷积在卷积神经网络(CNNs)中被广泛应用,用于聚合局部特征、扩大感受野并减少计算负担。然而,对于语义分割任务,对局部邻域的特征进行池化可能导致重要的空间信息丢失,这有助于逐像素预测。为了解决这个问题…

mysql 查询变量@i:=@i+1

学习完mysql的查询&#xff1a;基本查询&#xff0c;连接查询和子查询和mysql 正则表达式查询&#xff0c;接下来先学习下变量查询。 mysql中没有oracle序列号那一列。mysql可以使用查询变量的方式去处理。我们先了解下查询变量&#xff0c;后面应用起来就更清晰。 1&#xff0…

“弱智吧”才是人类面对AI的最后一道堡垒

在 AI 的研究领域中&#xff0c;语言模型的训练数据选择一直是一个关键问题。传统的智慧告诉我们&#xff0c;高质量的数据集应该是由专家精心挑选和校对的文本组成&#xff0c;以确保模型学习到的语言是规范、准确、有文化内涵的。 然而&#xff0c;最近的一项研究颠覆了这一观…

【Java】Java中类的初始化顺序(静态方法,静态块,非静态块,最后有流程图)

&#x1f4dd;个人主页&#xff1a;哈__ 期待您的关注 在日常使用Java的时候&#xff0c;我们都接触过new这个关键字&#xff0c;那你是否知道在我们的对象真正创建出来之前都做了哪些事情呢&#xff1f; 实际上要去判断一个类的初始化的顺序&#xff0c;需要分一下情况&…

Bean的默认名称

1.使用spring的注解 Component、Repository、Service、Controller 等注解去把一个类配置为bean时&#xff0c;如果不指定bean的名称&#xff0c;那么bean的名称的默认规则是&#xff1a; ①类名的首字母小写&#xff0c;例如&#xff1a;类名称 UserDao &#xff0c;那么默认的…

C++笔记:STL容器库的使用

前置&#xff1a; 对于stl容器库&#xff0c;我只做了一些常用的笔记&#xff0c;关于更详细的使用可以参考:https://cppreference.com/https://cppreference.com/ 一.string--字符串 对于C中string字符串会比C语言的字符数组使用起来会顺手许多。 命名空间&#xff1a;std 关于…

使用串口给ESP8266发送AT指令无反应解决

解决方法&#xff1a;重新烧录固件 设置PC机波特率 设置PC机上的端口波特率和flash下载工具中的波特率一致&#xff0c;否则flash下载工具会一直提示串口连接失败。我这里将PC机上的串口波特率设置为115200&#xff0c;然后flash下载工具波特率也设置为115200 Windows系统上…

电脑远程控制esp32上的LED

1、思路整理 首先esp32需要连接上wifi 然后创建udp socket 接受udp数据 最后解析数据&#xff0c;控制LED 2、micropython代码实现 import network from socket import * from machine import Pin p2Pin(2,Pin.OUT)def do_connect(): #连接wifi wlan network.WLAN(network.…

芒果YOLOv8改进组合157:动态标签分配ATSS+新颖高效AsDDet检测头组合改进,共同助力VisDrone涨点1.8%,小目标高效涨点

💡本篇内容:【芒果YOLOv8改进ATSS标签分配策略|第三集】芒果YOLOv8改进组合157:动态标签分配ATSS+新颖高效AsDDet检测头组合改进,共同助力VisDrone涨点1.8%,小目标高效涨点 💡🚀🚀🚀本博客 标签分配策略ATSS改进+ 新颖高效AsDDet检测头组合改进,适用于 YOLOv8 …

超详细解读Transformer框架

Transformer是由谷歌大脑2017年在论文《Attention is All You Need》中提出的一种序列到序列(Seq2Seq)模型。自提出伊始&#xff0c;该模型便在NLP和CV界大杀四方&#xff0c;多次达到SOTA效果。NLP领域中&#xff0c;我们所熟知的BERT和GPT就是从Transformer中衍生出来的预训练…

使用Ollama在本地运行AI大模型gemma

1.下载&#xff1a; https://github.com/ollama/ollama/releases 2.配置环境变量 我的电脑-右键-属性-系统-高级系统设置-环境变量-【系统环境变量】新建 变量名&#xff1a;OLLAMA_MODELS &#xff08;固定变量名&#xff09; 变量值&#xff1a;E:\Ollama\Lib &#xff0…

iOS 开发中上传 IPA 文件的方法(无需 Mac 电脑)

引言 在 iOS 开发中&#xff0c;将 IPA 文件上传到苹果开发者中心是一个重要的步骤。通常情况下&#xff0c;我们需要使用 Mac 电脑上的 Xcode 或 Application Loader 工具来完成这个任务。然而&#xff0c;如果你没有 Mac 电脑&#xff0c;也没有关系&#xff0c;本文将介绍一…

express里面的鉴权及express-session中间件的使用总结

了解 HTTP 协议的无状态性是进一步学习 Session 认证机制的必要前提。http 协议的无状态性&#xff0c;指的是客户端的每次 http 请求都是独立的&#xff0c;连续多个请求之间没有直接的关系&#xff0c;服务器不会主动保留每次 http 请求的状态。 什么是 Cookie Cookie 是存储…

如何在CentOS安装Nexus容器无公网IP远程管理本地仓库

文章目录 1. Docker安装Nexus2. 本地访问Nexus3. Linux安装Cpolar4. 配置Nexus界面公网地址5. 远程访问 Nexus界面6. 固定Nexus公网地址7. 固定地址访问Nexus Nexus是一个仓库管理工具&#xff0c;用于管理和组织软件构建过程中的依赖项和构件。它与Maven密切相关&#xff0c;可…

LeetCode-394. 字符串解码【栈 递归 字符串】

LeetCode-394. 字符串解码【栈 递归 字符串】 题目描述&#xff1a;解题思路一&#xff1a;辅助栈法解题思路二&#xff1a;递归法解题思路三&#xff1a;0 题目描述&#xff1a; 给定一个经过编码的字符串&#xff0c;返回它解码后的字符串。 编码规则为: k[encoded_string]…