当前位置: 首页 > article >正文

6.1 MySQL数字函数和条件函数

以前我们在课程中使用过一些mysql的内置函数,比如说四舍五入的round函数,做日期计算的data, datediff函数等等。那么本次课程咱们就来系统的学习一下mysql的这些内置函数,我们使用编程语言写程序的时候,通常会把某一项业务功能封装的函数里边,其实数据库也是这么做的,它为我们预先定义了很多函数,以供我们去使用

一、数字函数 

函数功能用例
ABS绝对值ABS(-100)
ROUND四舍五入ROUND(4.62)
FLOOR强制舍位到最近的整数FLOOR(9.9)
CEIL强制进位到最近的整数CEIL(3.2)
POWER幂函数POWER(2,3)
LOG对数函数LOG(7,3)
LN对数函数LN(10)
SQRT开平方SQRT(9)
PI圆周率PI()
SIN三角函数SIN(1)
COS三角函数COS(1)
TAN三角函数TAN(1)
COT三角函数COT(1)
RADIANS角度转换弧度RADIANS(30)
DEGREES弧度转换角度DEGREES(1)

二、条件函数

Mysql里边给我们提供了两个函数,可以实现简单的条件判断。比如说ifnull这个函数我们并不陌生了,那么它是用来判断某一个值是否为null值。如果为now

还有一个函数叫做if函数,这个函数非常像编程语言里边的三元运算符。当这个表达式结果为真的情况下,返回的是第一个值。如果说前面的表达式的结果为false, 那么返回的是第二个值

 练习1:中秋节公司发放礼品,SALES部门发放礼品A,其余部门发放礼品B,打印每名员工获得的礼品

select
e.empno,e.ename,d.dname,
if(d.dname="SALES","礼品A","礼品B")
from t_emp e join t_dept d on e.deptno=d.deptno

 练习2:公司年庆决定组织员工去集体旅游,每个部门的旅游目的地是不相同的。比如说SALES部门去P1,ACCOUNTING这个部门去P2的地点,RESEARCH部门去P3地点,查询每名员工的旅游地点

select
e.empno,e.ename,
(case
   when(d.dname="SALES") then("P1")
	 when(d.dname="ACCOUNTING") then("P2")
	 when(d.dname="RESEARCH") then("P3")
end) as place
from t_emp e join t_dept d on e.deptno=d.deptno

 练习3:公司决定为员工调整基本工资,具体调整方案如下

序号条件涨幅
1SELES部门里工龄超过20年10%
2SELES部门里工龄不满20年5%
3ACCOUNTING部门+300元
4RESEARCH部门里低于部门平均底薪+200元
5没有部门的员工+100元
update
t_emp e left join t_dept d on e.deptno=d.deptno
left join (select deptno,avg(sal) as avg from t_emp group by deptno) t
on e.deptno=t.deptno
set e.sal=(
case
	when d.dname="SALES" and datediff(now(),e.hiredate)/365>20
	then e.sal*1.1
	when d.dname="SALES" and datediff(now(),e.hiredate)/365<20
	then e.sal*1.05
	when d.dname="ACCOUNTING"
	then e.sal+300
	when d.dname="RESEARCH" and e.sal<t.avg
	then e.sal+200
	when e.deptno is null then e.sal+100
  else e.sal
end)


http://www.kler.cn/a/504191.html

相关文章:

  • HTML应用指南:利用GET请求获取星巴克门店数据
  • 《机器学习》——贝叶斯算法
  • 2025 年 UI 大屏设计新风向
  • 【算法学习】——整数划分问题详解(动态规划)
  • ElasticSearch 同义词匹配
  • 量子计算:从薛定谔的猫到你的生活
  • 开源项目stable-diffusion-webui部署及生成照片
  • electron打包不成功,放置安装包到C盘缓存
  • 论文阅读:EasySplat: View-Adaptive Learning makes 3D Gaussian Splatting Easy
  • 了解如何学习自然语言处理技术
  • 企业级信息系统开发讲课笔记4.12 Spring Boot默认缓存管理
  • CHAIN OF RESPONSIBILITY(职责链)—对象行为型模式
  • 对象数组按照指定rule对数据进行切割分层形成树形结构并支持搜索功能
  • 稀疏矩阵:BM25;稠密矩阵:RoBERTa - wwm - ext顺序
  • 目标客户营销(ABM)结合开源AI智能名片2+1链动模式S2B2C商城小程序的策略与实践
  • 二进制、八进制、十进制和十六进制的相互转换
  • 力扣经典题目之55.跳跃游戏
  • lwip单网卡多ip的实现
  • Python海龟绘图库:从入门到精通 - Python官方文档(三万字解析!)
  • Ubuntu20.04复现GraspNet全记录(含遇到的问题及解决方法
  • C语言——动态内存管理
  • pytorch小记(五):pytorch中的求导操作:backward()
  • 向u-boot提交补丁的流程
  • 【高可用自动化体系】自动化体系
  • [NOIP2007 提高组] 矩阵取数游戏
  • 如何物理连接Franka机械臂