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(); #[email protected]

#五、流程控制函数
#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;

时间: 2024-08-29 07:09:02

04_MySQL常见函数_单行函数的相关文章

Using Single-Row Functions to Customize Output使用单行函数自定义输出

DUAL is a public table that you can use to view results from functions and calculations. SQL> select * from DUAL; D - X SQL> desc DUAL; Name                                      Null?    Type ----------------------------------------- -------- ------

数据库 day60,61 Oracle入门,单行函数,多表查询,子查询,事物处理,约束,rownum分页,视图,序列,索引

1.    oracle介绍 ORACLE数据库系统是美国ORACLE公司(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一.比如SilverStream就是基于数据库的一种中间件.ORACLE数据库是目前世界上使用最为广泛的数据库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能:作为一个关系数据库,它是一个完备关系的产品:作为分布式数据库它实现了分布式处理功能.但它的所有知识,只要在一种机型上学习

Oracle笔记(五) 单行函数

Oracle笔记(五) 单行函数 虽然各个数据库都是支持SQL语句的,但是每一个数据库也有每一个数据库自己所支持的操作函数,这些就是单行函数,而如果要想进行数据库开发的话,除了要会使用SQL之外 ,就是要多学习函数. 单行函数主要分为以下五类:字符函数.数字函数.日期函数.转换函数.通用函数: 一.字符函数 字符函数的功能主要是进行字符串数据的操作,下面给出几个字符函数: UPPER(字符串 | 列):将输入的字符串变为大写返回: LOWER(字符串 | 列):将输入的字符串变为小写返回: IN

SQL含义+单行函数

1.SQL含义 SQL(Structured Query Language)结构化查询语言. 查询是一种从一个或多个表或视图中检索数据的操作,不会改变表中的数据. 查询数据是数据库的核心操作,是使用频率最高的操作. 2.select的表结构 select语句的基本用法格式 select[distinct]* |列名1[as c1],列名2[as c2]...,列名n,组函数(...) from 表名1 别名1,表名2 别名2... [where 条件] [group by 列名1,列名2....

DQL---条件查询、单行函数、多行函数、分组函数、数据类型

一.DQL 1.基本规则: (1)对于日期型数据,做 *,/ 运算不合法,可以进行 +, - 运算.比如给日期加一天或减一个月,结果仍为一个日期.两个日期间只能为减法,返回两个日期相差的天数,两个日期间做加法没任何意义. (2)包含空值(null)的数学表达式计算结果均为空值. (3)给字段取别名时,别名使用 双引号 括起来(根据双引号里的内容显示),不加双引号时会转为大写.字段与别名间可以使用AS关键字,也可使用空格. (4)oracle中连接字符是 || (也可以使用单行函数concat()

sql的基础语句-单行函数,dual,数字函数,日期函数,表连接,集合运算,分组报表,单行子查询,多行子查询

3. 单行函数 3.1 转换函数 select ascii('A'),chr(65) from dual; select to_char(1243123),1231451 from dual;靠左边的就是字符串,靠右边的就是数字 select to_char(123512a121) from dual;   --错误的写法,没有引号表示数字,但是数字里面包含了字母,不合法的输入值 select to_number('123141211') from dual; select to_number(

MySQL高级查询函数(单行函数)

函数的分类:1,单行函数:对每一条记录输入值进行计算,得到相应的计算结果,返回给用户,也就是说,每条记录作为一个输入参数,经过函数计算得到每条记录的计算结果.2,多行函数:对多条记录输入值进行计算,得到多条记录对应的单个结果. 单行函数: ①:字符串函数(用户处理单行的字符数据,比如大小写转换,字符串截取,拼装等) a.LOWER/UPPER(LOWER(str):返回字符串str变为小写字母的字符串.UPPER(str):返回字符串str变为大写字母的字符串) SELECT UPPER(nam

单行函数

1.单行函数: 操作数据对象接收函数返回一个结果只对一行进行操作每行返回一个结果可以转换数据类型可以嵌套参数可以是一列或一个值 2.单行函数分为: 字符: SELECT employee_id, CONCAT(first_name, last_name) NAME, job_id, LENGTH (last_name), INSTR(last_name, 'a') "Contains 'a'?" FROM employees WHERE SUBSTR(job_id, 4) = 'REP

Oracle笔记(三)单行函数

-函数 函数像一个黑盒子一样(看不到里边的构造),有参数返回值,可以为我们完成一定的功能. -单行 这种函数会对结果中的每一行计算一次,每行返回一个结果,单行概念区别于分组函数. 单行函数主要分为以下五类:字符函数.数字函数.日期函数.转换函数.通用函数: 一.字符型函数 ---字符处理-大小写转换 例子:写一个SQL,将'I love Sql'转换成全大写,全小写和首字母大写的形式. SELECT UPPER ('I love Sql'),LOWER('I love Sql'),INITCAP