04_MySQL常见函数_单行函数
#单行函数细分
1、字符函数
2、数学函数
3、日期函数
4、其他函数
5、流程控制函数
#单行函数 - 字符函数
#一、字符函数
#1. length 获取参数的字节长度
SELECT LENGTH('john');
SELECT LENGTH('张三丰'); #utf-8编码,1个汉字3个字节
# 查看当前客户端的字符集
SHOW VARIABLES LIKE '%char%';
#2. concat 拼接字符
SELECT CONCAT(last_name,'_',first_name) FROM employees;
#3. upper,lower
SELECT UPPER('john');
SELECT LOWER('JOHN');
#案例:将姓变大写,将名变小写,然后拼接
SELECT CONCAT(UPPER(first_name), LOWER(first_name)) AS "姓名" FROM employees;
#4. substr, substring(同一个函数)
#4个重载的方法
# 注意:SQL语言的索引从1开始
# 作用:截取从pos开始的所有字符,包括pos
SELECT SUBSTR('zhangjin', 6); # jin
# 作用:截取从pos开始, 字符长度为len的子串
SELECT SUBSTR('zhangjin',1,5); # zhang
# 案例:姓名中首字母大写,其他字符小写
SELECT CONCAT(UPPER(SUBSTR(last_name,1,1)), LOWER(SUBSTR(last_name,2)))
AS "姓"
FROM employees;
#5. instr 返回子串第一次出现的起始索引,没有出现则返回0
SELECT INSTR('zhangjin','shay'); # 0
SELECT INSTR('zhangjin','jin'); # 6
SELECT INSTR('zhangjinjinjinjinjinjin','jin'); # 6
#6、trim
# 默认是trim左右两边的空格
SELECT TRIM(' zhangjin ');
# 可以指定要trim的字符
SELECT TRIM('a' FROM 'aaaaaazhangjinaaaa');
#7、lpad
#使用指定字符进行左填充,填充后的字符个数为len
#len,字符个数,并不是字节长度
SELECT LPAD('张',3,'*'); # **张
#最终长度由len决定
SELECT LPAD('张三丰',2,'*'); # 张三
#8、rpad
#使用指定字符进行右填充,填充后的字符个数为len
#len,字符个数,并不是字节长度
SELECT RPAD('张',3,'*'); # 张**
#最终长度由len决定
SELECT RPAD('张三丰',2,'*'); # 张三
#9、replace
# replace(str,from_str,to_str) 全部替换,replace_all
SELECT REPLACE('zhangjin', 'zhang', 'shay');
SELECT REPLACE('zhangjinzhangjinzhangjin', 'zhang', 'shay');
#二、数学函数
#round 四舍五入
SELECT ROUND(1.45);
SELECT ROUND(-1.65);
SELECT ROUND(1.567,2); #保留2位小数
#ceil 向上取整, 返回大于等于该参数的最小整数
SELECT CEIL(1.002); #2
SELECT CEIL(1.00); #1
#floor 向下取整,返回小于等于该参数的最大整数
SELECT FLOOR(1.002); #1
#truncate 截断
SELECT TRUNCATE(1.65,1); #保留1位小数
#mod 取余数
SELECT MOD(10,3); # 10%3=1
SELECT MOD(-10,-3); # -1, 被除数为负数,结果为负数
#三、日期函数
#now 返回当前系统日期+时间
select now();
#curdate 返回当前系统日期,不包括日期
select curdate();
#curtime 返回当前时间,不包括日期
select curtime();
#可以获取指定的部分:年,月,日,时,分,秒
# 获取年
select year(now()) as 年;
select year('1986-1-1');
select year(hiredate) from employees;
# 获取月
select month(now()) as 月; # 11
select monthname(now()) as 月; # November
# 获取日
select day(now()) as 日; # 24
select dayname(now()) as 日; # Friday
s
# 将日期格式的字符串 -> 日期
# str_to_date('24-11-2017', '%d-%m-%Y');
select str_to_date('24-11-2017', '%d-%m-%Y');
# 案例:将用户输入的4-3 1992作为查询依据,找出在1992年4月3日入职的员工
select * from employees where hiredate = str_to_date('4-3 1992', '%c-%d %Y');
# 日期 -> 字符
# date_format('2018/6/6', '%Y年%m月%d日')
select date_format('2018/6/6', '%Y年%m月%d日');
# 案例:查询有奖金的员工名和入职日期(XX月/XX日 XX年)
select last_name,date_format(hiredate, '%m月/%d日 %y年') as 入职日期
from employees
where commission_pct is not null;
#四、其他函数
# mysql版本查询
SELECT VERSION();
# 当前使用的数据库查询
SELECT DATABASE();
# 查询当前用户
SELECT USER(); #root@localhost
#五、流程控制函数
#1、if函数
# if(exp1,exp2,exp3) exp1为true, 返回exp2的值,否则返回exp3的值
SELECT last_name, IF(commission_pct IS NULL, '无', '有') FROM employees;
#2、case控制结构的使用一:switch case的效果
/*
适合:等值判断
mysql中case控制结构:
case 要判断的字段或表达式
when 常量1 then 要显示的值1或语句1;
when 常量2 then 要显示的值2或语句2;
when 常量3 then 要显示的值3或语句3;
when 常量4 then 要显示的值4或语句4;
else 要显示的值n或语句n;
end
*/
/*案例:查询员工的工资,要求
部门号=30,显示的工资为1.1倍
部门号=40,显示的工资为1.2倍
部门号=50,显示的工资为1.3倍
其他部门,显示工资为原工资
*/
SELECT salary,department_id,
CASE department_id
WHEN 30 THEN 1.1*salary
WHEN 40 THEN 1.2*salary
WHEN 50 THEN 1.3*salary
ELSE salary
END
AS "新工资"
FROM employees;
#3、case控制结构的使用二:类似多重if
/*
mysql中case控制结构:
适合:区间判断(大小)
case
when 条件1(true,false) 要显示的值1(尾部不加分号)或语句1(尾部加分号)
when 条件2(true,false) 要显示的值2(尾部不加分号)或语句2(尾部加分号)
....
else 要显示的值n(尾部不加分号)或语句n(尾部加分号)
end
*/
#案例:查询员工的工资情况
/*
如果工资大于2万,显示A级别
如果工资大于1万5,显示B级别
如果工资大于1万,显示C级别
否则,显示D级别
*/
SELECT salary,
CASE
WHEN salary>20000 THEN 'A'
WHEN salary>15000 THEN 'B'
WHEN salary>10000 THEN 'C'
ELSE 'D'
END
AS "工资级别"
FROM employees;
04_MySQL常见函数_单行函数的更多相关文章
- 05_MySQL常见函数_分组函数
# 分组函数/*功能: 统计,又称为聚合函数,统计函数,组函数 传入一组值,统计后得到一个值 分类: sum 求和,avg 平均值,max 最大值,min 最小值,count 计算个数 特点: 1. ...
- Oracle Day2 过滤、排序、单行函数
1.过滤和排序 SQL> --查询10号部门的所有员工信息 SQL> select * from emp ; 未选定行 SQL> ed SP2: 无法创建保存文件 "afi ...
- Oracle01——基本查询、过滤和排序、单行函数、多行函数和多表查询
作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7272236.html Oracle的集群 Oracle的体系结构 SQL> --当 ...
- Oracle单行函数
一.尽管各个数据库都是支持sql语句的.可是每一个数据库也有每一个数据库所支持的操作函数,这些就是单行函数.假设想进行数据库开发的话.除了要回使用sql语句外,就是要多学习函数. 1.单行函数的分类: ...
- Oracle数据库从入门到精通 单行函数问题
视频课程:李兴华 Oracle从入门到精通视频课程 学习者:阳光罗诺 视频来源:51CTO学院 Oracle数据库从入门到精通-单行函数 在数据库中,为了方便用户的数据开发,往往会提供一系列的支持函数 ...
- Oracle数据库之六 单行函数
六.单行函数 6.1.认识单行函数 函数就是和 Java 语言之中的方法的功能是一样的,都是为了完成某些特定操作的功能支持,而在 Oracle 数据库里面也包含了大量的单行函数,这些函数掌握了以后 ...
- DQL---条件查询、单行函数、多行函数、分组函数、数据类型
一.DQL 1.基本规则: (1)对于日期型数据,做 *,/ 运算不合法,可以进行 +, - 运算.比如给日期加一天或减一个月,结果仍为一个日期.两个日期间只能为减法,返回两个日期相差的天数,两个日期 ...
- Oracle笔记(五) 单行函数
虽然各个数据库都是支持SQL语句的,但是每一个数据库也有每一个数据库自己所支持的操作函数,这些就是单行函数,而如果要想进行数据库开发的话,除了要会使用SQL之外 ,就是要多学习函数. 单行函数主要分为 ...
- SQL语句(二)数据排序和单行函数
目录 一.排序查询 1. 基本排序 2. 多条件排序 二.单行函数 调用方法 字符函数 ①LENGTH函数 ②CONCAT函数 ③upper 和 lower ④substr ⑤instr ⑥trim ...
随机推荐
- 如何使用 libtorch 实现 LeNet 网络?
如何使用 libtorch 实现 LeNet 网络? LeNet 网络论文地址: http://yann.lecun.com/exdb/publis/pdf/lecun-01a.pdf
- CF #301 E:Infinite Inversions(逆序数,树状数组)
A-Combination Lock B-School Marks C-Ice Cave D-Bad Luck Island E-Infinite Inversions E:Infini ...
- Linux cal命令
cal命令时查看日历的相关命令 1.用法 cal [选项] [[[日] 月] 年] 2.命令选项 -1, --one 只显示当前月份(默认) -3, --three 显示上个月.当月和下个月 -s, ...
- webpack无法通过 IP 地址访问 localhost 解决方案
解决方案: 在config里面的index.js里面的module.exports下面的dev下面的host:'localhost' 改为 host:'0.0.0.0',就可以访问啦!
- 使用paramiko执行远程linux主机命令
paramiko是python的SSH库,可用来连接远程linux主机,然后执行linux命令或者通过SFTP传输文件. 关于使用paramiko执行远程主机命令可以找到很多参考资料了,本文在此基础上 ...
- POJ1185:炮兵阵地(状压dp)
题目:http://poj.org/problem?id=1185 大神的题解: 方法就是用DP[i][r][p]表示第i行状态为r,第i-1行状态是p时的最多个数.而这里p受到r的限制,而第i-2行 ...
- MySQL · 引擎特性 · InnoDB redo log漫游(转)
前言 InnoDB 有两块非常重要的日志,一个是undo log,另外一个是redo log,前者用来保证事务的原子性以及InnoDB的MVCC,后者用来保证事务的持久性. 和大多数关系型数据库一样, ...
- 20165324 《Java程序设计》 第六周
学号 2016-2017-2 <Java程序设计>第六周学习总结 教材学习内容总结 第八章 常用实用类 String类 构造String对象:常量对象:String对象:引用String常 ...
- 20165324 Java实验一
20165324 实验一 一.实验报告封面 课程:Java程序设计 班级:1653班 姓名:何春江 学号:20165324 指导教师:娄嘉鹏 实验日期:2018年4月2日 实验时间:13:45 - 1 ...
- B-、B+、B*树
B-树:多路搜索树,每个结点存储M/2到M个关键字,非叶子结点存储指向关键字范围的子结点:所有关键字在整颗树中出现,且只出现一次,非叶子结点可以命中: B+树:在B-树基础上,为叶子结点增加链表指针, ...