简单的SQL语句的快速复习
语法的执行顺序
select 4 字段列表
from 1 表名列表
where 2 条件列表
group by 3 分组前过滤
having 分组后过滤
order by 5 排序字段列表
limit 6 分页参数
聚合函数
count 统计数量
max 最大值
min 最小值
avg 平均
sum 总和
分组查询使用例子
1.性别分组,统计数量
select gender ,count(*)from emp group by gender
2.性别分组 统计平均年龄
select age ,avg(age) from emp group by gender
3.查询年龄小于45的员工,并且按照工作地址分组,获取员工数量>=3的工作地址
首先
按工作地址分组然后获取年龄小于45的员工的地址信息的总数
select workaddress,count(*)from emp where age<45 group by workaddress
再分组完后进行过滤
having count(*)>=3
排序查询使用例子
语法:
select 字段列表 from 表名 order by 字段1 排序方式1,字段2,排序方式2;
排序方式:
1.ASC:升序(默认)
2.DESC:降序
例子
1.根据年龄进行排序,2.年龄相同,再入职日期降序排序
select age from emp order by ageasc,entrydate desc
多字段排序:第一个字段相同时再进行第二个字段排序
分页查询
语法
select 字段列表 from 表名 limit 起始索引,查询记录数;
select * from emp limit 0 10
函数
字符串函数
concat(s1,s2,s3)字符串的拼接
lower(str) 小写
upper(str)大写
lpad(str,n,pad)
左填充,用字符串pad对左边进行填充,达到n个字符串长度
rpad(str,n,pad)
右填充
trim(str)
去掉字符串头部和尾部的空格
substring(str,start,len)
返回字符串str从str位置起的len个长度的字符串
如
int类型不能补0,因为是整形但可以补1
数值函数
ceil(x) 向上取整
floor(x) 向下取整
mod(X,Y) 返回x/y的模
rand()返回0-1内的随机数
round(X,Y)四舍五入,保留y位小数
日期函数
curdate() 日期
curtime() 时间
now() 现在
year(date) 获取指定date的年份
month(date) 获取指定date的月份
day(date) 日期
date-add(date,interval exprtype)
返回这个日期加上一个时间间隔后的时间值
datediff(date1,date2)
返回起始时间date1和结束时间date2之间的天数
流程函数
if(value,t,f)
true返回t
false返回f
ifnull(value1,value2)不空返回value1,空的话返回value2
case when then
case when [val]then [res1] else [defaulse] End
val为true则返回res1
否则返回default默认值
case [expr] when [val] then [res1] else [default] End
end是结束
当expr的值等于val时返回res1否则返回default
使用例子
select name,(case workaddress when'北京' then'一线',when‘上海’,then‘一线’ end)as‘工作地址’
增删改查
添加数据
1.给指定字段添加数据 insert values
insert into 表名(字段1 , 字段2) values(值1,值2)
2.给全部字段添加数据(不写出具体字段名)
insert into 表名 values(值1,值2)
3.批量添加数据
给特定字段
insert into 表名(字段1,字段2)values(值1,值2)(值1,值2);
给全部字段
insert into 表名 values (值1,值2), (值1,值2), (值1,值2);
更新与删除
修改数据:update set
update 表名 set 字段名1=值1,字段名2=值2......[where 条件]
不写条件where的话就是所有都执行
删除数据 delete
delete from 表名 [where 条件]
联合查询(union)
union查询,就是把多次的查询结果合并起来形成一个新的查询结果
select 字段列表 from 表a
union[all]
select 字段列表 from 表b
分别查询薪资>5000,年龄>50的员工
select *from emp where salary>5000
union all
select *from emp where age>50
但是结果会有重复的,为了去重
可以把all去
报错情况
select *from emp where salary>5000
union all
select name from emp where age>50
这个会发现报错
因为对于联合查询来说。字段表的列数和字段类型必须保持一致
子查询
子查询
又称为 嵌套查询
标量子查询
查询销售部的所有员工信息
1. select id from emp where name='销售部';
第一部查询出销售部id等于4
2.select *from emp where dept_id=4;
要两条指令,但我们想用一条搞定
select *from emp where dept_id=(select id from emp where name='销售部');
列子查询
常用操作符:
in,not in,any,some,all
1
select id from dept where name='销售部'or name='市场部';
查出的id是1和2
然后
select* from emp where dept_id in (1,2)
或者
select* from emp where dept_id in (select id from dept where name='销售部'or name='市场部');
2
查询比财务部的所有人工资都高的员工的 信息
a 查询所有财务部人员的工资
select id from dept where name='财务部';
select salary from emp where dept_id=3
b查询比财务部所有人工资都高的员工信息
select *from emp where salary> all( select salary from emp where dept_id=3)
3
查询比研发部其中任意一人工资都高的员工信息
因为是任意一人所以 没有all
行子查询
查询与‘张无忌’薪资以及领导都相同的员工的信息
a.查询张无忌的工资及其领导
select salary,managerid from emp where name='张无忌'
b. 查询员工
select *from emp where salary=12500 and mangerid =1;
或者
select *from emp where (salary,managerid)=(12500,1);
再或者
select *from emp where(salary,mangerid)=(select salary,managerid from emp where name='张无忌')
表子查询
常用操作符 in
1.查询与‘路’和‘白’薪资以及职位相同的员工
select job,salary from emp where name='路'or name=‘白’
select * from emp where (job,salary) in(select job,salary from emp where name='路'or name=‘白’)
2.查询入职日期是“2006-01-01”之后的员工信息,及其部门信息
select * from emp where entrydate>"2006-01-01"
把上面那个作为临时表
select e.*,d.* from(select * from emp where entrydate>"2006-01-01") e left join dept d on e.dept_id=d.id
多表联查
1.查询员工的姓名,年龄,职位,部门信息(隐式内连接)
表:emp dept
连接条件:emp.dept_id=dept.id
记得消除笛卡尔积
select e.name,e.age,e.job,d.name from emp e, dept d where e.dept_id=d.id;
2.查询年龄小于30岁的员工的姓名,年龄,职位,部门信息(显示内连接)
select e.name,e.age,e.job,d.name from emp e inner join dept d on e.dept_id=d.id where e.age<30
3.查询拥有员工的部门id和部门名称
求取员工表和部门表之间的交集用内连接
select d.id,d.name from emp e,dept d where e.dept_id=d.id
此时会有多个重复的部门,因为他是按照员工数量来的
去重复用 distinct
select distinct d.id,d.name from emp e,dept d where e.dept_id=d.id
4.查询所有年龄大于40的员工,及其归属部门的名称;如果员工没有分配部门也要显示出来
要用外连接
select e.*,d.name from emp e left join dept d on e.dept_id=d.id where e.age>40
5.查询所有员工的工资等级
表:emp salarygrade
连接条件:emp.salary >=salagrade.losal and emp.salary<=salagrade.hisal
select e.*,s.grade emp e,salagrade s where e.salary>=s.losal and e.salary <=s.hisal
第二种写法:
select e.*,s.grade emp e,salagrade s where e.salary between s.losal and s.hisal
6.查询 研发部 所有员工的信息以及工资等级
涉及到的表:emp dept salgrade
连接条件:
emp.salary between s.losal and s.hisal
emp.dept_id=dept.id
查询条件 dept.name='研发部'
select e.*,s.grade from emp e ,dept d,salgrade s where e.dept_id=d.id and ( emp.salary between s.losal and s.hisal)and d.name='研发部'
7.查询研发部员工的平均工资
表 emp dept
select avg(e.salary) from emp e, dept d where e.dept_id=d.id and e.name='研发部'
8.查询工资比‘灭绝’高的员工信息
select * from emp where salary>(select salary from emp where name='灭绝')
查询灭绝的薪资
select salary from emp where e.name='灭绝'
9.查询比平均薪资高的员工信息
select avg(salary) from emp
select * from emp where salary>(select avg(salary) from emp)
10.查询低于 本部门 平均薪资的员工
a.查询指定部门的平均薪资
select avg(e.salary) from emp e where e.dept_id=1
select avg(e.salary) from emp e where e.dept_id=2
b.
select *from emp e2 where salary<(select avg(e.salary) from emp e where e.dept_id=e2.dept_id)
保证平均下来的薪资是同一个部门的
11.查询所有的部门信息,并统计部门的员工人数
a.查询信息
select id,name from dept
b.查询指定部门的人数
select count(*) from emp where dept_id=1
最终
select d.id ,d.name (select count(*) from emp e where e.dept_id=id)'人数' from dept d;
12.查询所有学生的选课情况,展示出学生的名称,学号,课程名称
表:student ,course,student_course
连接条件:student.id=student_course.studentid,course.id=student_course.courseid
select s.name ,s.no,c.name from student s,student_course sc,course c where s.id=sc.studentid and sc.courseid=c.id
相关文章:
简单的SQL语句的快速复习
语法的执行顺序 select 4 字段列表 from 1 表名列表 where 2 条件列表 group by 3 分组前过滤 having 分组后过滤 order by 5 排序字段列表 limit 6 分页参数 聚合函数 count 统计数量 max 最大值 min 最小值 avg 平均 sum 总和 分组查询使…...

Spring MVC 综合案例
目录 一. 加法计算器 1. 准备工作 2. 约定前后端交互接口 需求分析 接口定义 3. 服务器端代码 4. 运行测试 二. 用户登录 1. 准备工作 2. 约定前后端交互接口 需求分析 接口定义 (1) 登录界面接口 (2) 首页接口 3. 服务器端代码 4. 运行测试 三. 留言板 1. 准备…...
Spring Boot多环境配置实践指南
在开发Spring Boot应用时,我们常常需要根据不同的运行环境(如开发环境、测试环境和生产环境)来配置不同的参数。Spring Boot提供了非常灵活的多环境配置机制,通过使用profile-specific properties文件,我们可以轻松地管…...
微信小程序中实现进入页面时数字跳动效果(自定义animate-numbers组件)
微信小程序中实现进入页面时数字跳动效果 1. 组件定义,新建animate-numbers组件1.1 index.js1.2 wxml1.3 wxss 2. 使用组件 1. 组件定义,新建animate-numbers组件 1.1 index.js // components/animate-numbers/index.js Component({properties: {number: {type: Number,value…...
【huawei】云计算的备份和容灾
目录 1 备份和容灾 2 灾备的作用? ① 备份的作用 ② 容灾的作用 3 灾备的衡量指标 ① 数据恢复时间点(RPO,Recoyery Point Objective) ② 应用恢复时间(RTO,Recoyery Time Objective) 4…...
Vue.js组件开发-实现下载时暂停恢复下载
在 Vue 中实现下载时暂停和恢复功能,通常可以借助 XMLHttpRequest 对象来控制下载过程。XMLHttpRequest 允许在下载过程中暂停和继续请求。 实现步骤 创建 Vue 组件:创建一个 Vue 组件,包含下载、暂停和恢复按钮。初始化 XMLHttpRequest 对…...
TCP是怎么判断丢包的?
丢包在复杂的网络环境中,是一种常见的现象。 TCP(传输控制协议)作为一种可靠传输协议,内置了多种机制来检测和处理丢包现象,从而保证数据的完整性和传输的可靠性。本文将介绍TCP判断丢包的原理和机制。 一、TCP可靠传…...

python爬虫入门(一) - requests库与re库,一个简单的爬虫程序
目录 web请求与requests库 1. web请求 1.1 客户端渲染与服务端渲染 1.2 抓包 1.3 HTTP状态代码 2. requests库 2.1 requests模块的下载 2.2 发送请求头与请求参数 2.3 GET请求与POST请求 GET请求的例子: POST请求的例子: 3. 案例:…...

2025年数学建模美赛 A题分析(3)楼梯使用方向偏好模型
2025年数学建模美赛 A题分析(1)Testing Time: The Constant Wear On Stairs 2025年数学建模美赛 A题分析(2)楼梯磨损分析模型 2025年数学建模美赛 A题分析(3)楼梯使用方向偏好模型 2025年数学建模美赛 A题分…...

复古壁纸中棕色系和米色系哪个更受欢迎?
根据最新的搜索结果,我们可以看到棕色系和米色系在复古壁纸设计中都非常受欢迎。以下是对这两种颜色系受欢迎程度的分析: 棕色系 受欢迎程度:棕色系在复古壁纸中非常受欢迎,因为它能够营造出温暖、质朴和自然的氛围。棕色系的壁纸…...
编译安装PaddleClas@openKylin(失败,安装好后报错缺scikit-learn)
编译安装 前置需求: 手工安装swig和faiss-cpu pip install swig pip install faiss-cpu 小技巧,pip编译安装的时候,可以加上--jobs64来多核编译。 注意先升级pip版本:pip install pip -U pip3 install faiss-cpu --config-s…...

t113_can增加驱动
1 基于太极派的SDK添加 //设备树添加can0: can2504000 {compatible "allwinner,sun20i-d1-can";reg <0x0 0x02504000 0x0 0x400>;interrupts <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;clocks <&ccu CLK_BUS_CAN0>;resets <&ccu RST_BUS_…...
达梦数据库建用户,键库脚本
-- 1.创建表空间 CREATE TABLESPACE "表空间名称" DATAFILE /dmdata/data/DAMENG/表空间名称.DBF SIZE 512 AUTOEXTEND ON NEXT 512 MAXSIZE UNLIMITED; -- 2.创建用户 CREATE USER "表空间名称" IDENTIFIED BY "表空间名称" HASH WITH SHA512 S…...

上海亚商投顾:沪指冲高回落 大金融板块全天强势 上海亚商投
上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 一.市场情绪 市场全天冲高回落,深成指、创业板指午后翻绿。大金融板块全天强势,天茂集团…...

MySQL 的索引类型【图文并茂】
基本分类 文本生成MindMap:https://app.pollyoyo.com/planttext <style> mindmapDiagram {node {BackgroundColor yellow}:depth(0) {BackGroundColor SkyBlue}:depth(1) {BackGroundColor lightGreen} } </style> * MySQL 索引** 数据结构角度 *** B树索引*** 哈…...
天聚地合:引领API数据流通服务,助力数字经济发展
天聚地合:引领API数据流通服务,助力数字经济发展 爱企猫01月24日消息:天聚地合(苏州)科技股份有限公司,成立于2010年,总部位于苏州,是一家综合性API数据流通服务商。公司旗下品牌‘聚合数据’已开发超过790个API,服务百万企业级客…...

【反悔堆】【hard】力扣871. 最低加油次数
汽车从起点出发驶向目的地,该目的地位于出发位置东面 target 英里处。 沿途有加油站,用数组 stations 表示。其中 stations[i] [positioni, fueli] 表示第 i 个加油站位于出发位置东面 positioni 英里处,并且有 fueli 升汽油。 假设汽车油…...

electron typescript运行并设置eslint检测
目录 一、初始化package.json 二、安装依赖 1、安装electron 2、安装typescript依赖 3、安装eslint 三、项目结构 四、配置启动项 一、初始化package.json 我的:这里的"main"没太大影响,看后面的步骤。 {"name": "xlo…...

服务器上安装Nginx详细步骤
第一步:上传nginx压缩包到指定目录。 第二步:解压nginx压缩包。 第三步:配置编译nginx 配置编译方法: ./configure 配置编译后结果信息: 第四步:编译nginx 在nginx源文件目录中直接运行make命令 第五步&…...
Timeout or no response waiting for NATS JetStream server
当使用jetStream 出现"Timeout or no response waiting for NATS JetStream server" 错误的时候要注意后面的“no response”,尤其是开发测试,要去check server 是否启动了 jet stream。 [20112] 2025/01/24 08:27:42.738396 [INF] _ ___…...

css实现圆环展示百分比,根据值动态展示所占比例
代码如下 <view class""><view class"circle-chart"><view v-if"!!num" class"pie-item" :style"{background: conic-gradient(var(--one-color) 0%,#E9E6F1 ${num}%),}"></view><view v-else …...
【Linux】C语言执行shell指令
在C语言中执行Shell指令 在C语言中,有几种方法可以执行Shell指令: 1. 使用system()函数 这是最简单的方法,包含在stdlib.h头文件中: #include <stdlib.h>int main() {system("ls -l"); // 执行ls -l命令retu…...

渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止
<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet: https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案
问题描述:iview使用table 中type: "index",分页之后 ,索引还是从1开始,试过绑定后台返回数据的id, 这种方法可行,就是后台返回数据的每个页面id都不完全是按照从1开始的升序,因此百度了下,找到了…...

【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

QT: `long long` 类型转换为 `QString` 2025.6.5
在 Qt 中,将 long long 类型转换为 QString 可以通过以下两种常用方法实现: 方法 1:使用 QString::number() 直接调用 QString 的静态方法 number(),将数值转换为字符串: long long value 1234567890123456789LL; …...

ios苹果系统,js 滑动屏幕、锚定无效
现象:window.addEventListener监听touch无效,划不动屏幕,但是代码逻辑都有执行到。 scrollIntoView也无效。 原因:这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作,从而会影响…...

tree 树组件大数据卡顿问题优化
问题背景 项目中有用到树组件用来做文件目录,但是由于这个树组件的节点越来越多,导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多,导致的浏览器卡顿,这里很明显就需要用到虚拟列表的技术&…...
Device Mapper 机制
Device Mapper 机制详解 Device Mapper(简称 DM)是 Linux 内核中的一套通用块设备映射框架,为 LVM、加密磁盘、RAID 等提供底层支持。本文将详细介绍 Device Mapper 的原理、实现、内核配置、常用工具、操作测试流程,并配以详细的…...
【前端异常】JavaScript错误处理:分析 Uncaught (in promise) error
在前端开发中,JavaScript 异常是不可避免的。随着现代前端应用越来越多地使用异步操作(如 Promise、async/await 等),开发者常常会遇到 Uncaught (in promise) error 错误。这个错误是由于未正确处理 Promise 的拒绝(r…...