目录
- I. MySQL 常用函数
- 1. 字符串函数
- a. 常用函数
- b. 导入数据
- c. 示例题目
- 2. 日期函数
- a. 常用函数
- b. 示例题目
- 3. 数字函数
- a. 常用函数
- b. 示例题目
- 4. 高级函数
- a. CASE 表达式
- i. 语法
- ii. 示例题目
- b. IF 表达式
- i. 语法
- ii. 示例题目
- II. MySQL 函数综合案例
- III. 附录
- 1. 数学函数
- 2. 聚合函数
- 3. 字符串函数
- 4. 日期和时间函数
- > DATE_FORMAT 可以使用的格式
- 5. 加密函数
- 6. 控制流函数
- 7. 格式化函数
- 8. 类型转化函数
- 9. 系统信息函数
I. MySQL 常用函数
- 为了简化操作,MySQL 提供了大量的函数给程序员使用。例如,要输入当前时间,可以调用 now() 函数。
- 函数可以出现的位置:插入语句的 values() 、更新语句、删除语句、查询语句及其子句中。
- 菜鸟教程:https://www.runoob.com/mysql/mysql-functions.html
1. 字符串函数
a. 常用函数
-
函数:
CONCAt(s1,s2...sn)
描述:字符串 s1,s2 等多个字符串合并为一个字符串
实例:select concat(‘Regino’,’-’,‘个人博客’); -
函数:
CHAR_LENGTH(str)
描述:返回字符串 str 的字符数
实例:select char_length(‘Hello,Regino’); -
函数:
LENGTH(str)
描述:返回字符串 str 的字节数
编码:UTF-8(一个中文字符占 3 个字节,中文标点占 3 个字节)
实例:select length(‘你好!’); -
函数:
UCASE(s)
|UPPER(s)
描述:将字符串转换为大写
实例:select ucase(‘regino’); -
函数:
LCASE(s) | LOWER(s)
描述:将字符串转换为小写
实例:select lcase(‘REGINO’); -
函数:
LOCATE(s1,s)
描述:从字符串 s 中获取 s1 的开始位置
注意:从 1 开始
实例:select locate(‘gi’,‘regino’);(返回 3) -
函数:
TRIm(str)
|LTRIm(str)
|RTRIm(str)
描述:字符串去空格(分别为两边、左边、右边去空格)
实例:select trim(’ 莘莘学子 '); -
函数:
REPLACE(s,s1,s2)
描述:将字符串 s2 替代字符串 s 中的字符串 s1
实例:select replace(‘abc’,‘b’,‘x’);(输出 axc) -
函数:
SUBSTr(s, start, length)
描述:从字符串 s 的 start 位置截取长度为 length 的子字符串
注意:从 1 开始
实例:select substr(‘regino’,‘2’,‘3’);(输出 egi) -
函数:
STRCMP(str1,str2)
描述:比较字符串大小,左大于右时返回 1,左等于右时返回 0,左小于于右时返回 -1
实例:select strcmp(‘a’,‘b’);(输出 -1)
b. 导入数据
- 可以通过 SQLyog,实现 SQL 脚本的导入(即还原,详见:MySQL 简述与基础语法 >> 图形化工具 SQLyog)。
-- 多表案例
create database regino;
use regino;
-- 部门表
CREATE TABLE dept (
id INT PRIMARY KEY auto_increment, -- 部门id
dname VARCHAR(50), -- 部门名称
loc VARCHAR(50) -- 部门位置
);
-- 添加4个部门
INSERT INTO dept(id,dname,loc) VALUES
(10,'教研部','北京'),
(20,'学工部','上海'),
(30,'销售部','广州'),
(40,'财务部','深圳');
-- 职务表
CREATE TABLE job (
id INT PRIMARY KEY,
jname VARCHAR(20), -- 职务名称
description VARCHAR(50) -- 职务描述
);
-- 添加4个职务
INSERT INTO job (id, jname, description) VALUES
(1, '董事长', '管理整个公司,接单'),
(2, '经理', '管理部门员工'),
(3, '销售员', '向客人推销产品'),
(4, '文员', '使用办公软件');
-- 员工表
CREATE TABLE emp (
id INT PRIMARY KEY, -- 员工id
ename VARCHAR(50), -- 员工姓名
job_id INT, -- 职务id 外键
mgr INT , -- 上级领导
joindate DATE, -- 入职日期
salary DECIMAL(7,2), -- 工资 99999.99
bonus DECIMAL(7,2), -- 奖金 99999.99
dept_id INT, -- 所在部门编号 外键
CONSTRAINT emp_jobid_ref_job_id_fk FOREIGN KEY (job_id) REFERENCES job (id),
CONSTRAINT emp_deptid_ref_dept_id_fk FOREIGN KEY (dept_id) REFERENCES dept (id)
);
-- 添加员工
INSERT INTO emp(id,ename,job_id,mgr,joindate,salary,bonus,dept_id) VALUES
(1001,'孙悟空',4,1004,'2000-12-17','8000.00',NULL,20),
(1002,'卢俊义',3,1006,'2001-02-20','16000.00','3000.00',30),
(1003,'林冲',3,1006,'2001-02-22','12500.00','5000.00',30),
(1004,'唐僧',2,1009,'2001-04-02','29750.00',NULL,20),
(1005,'李逵',4,1006,'2001-09-28','12500.00','14000.00',30),
(1006,'宋江',2,1009,'2001-05-01','28500.00',NULL,30),
(1007,'刘备',2,1009,'2001-09-01','24500.00',NULL,10),
(1008,'猪八戒',4,1004,'2007-04-19','30000.00',NULL,20),
(1009,'罗贯中',1,NULL,'2001-11-17','50000.00',NULL,10),
(1010,'吴用',3,1006,'2001-09-08','15000.00','0.00',30),
(1011,'沙僧',4,1004,'2007-05-23','11000.00',NULL,20),
(1012,'李逵',4,1006,'2001-12-03','9500.00',NULL,30),
(1013,'小白龙',4,1004,'2001-12-03','30000.00',NULL,20),
(1014,'关羽',4,1007,'2002-01-23','13000.00',NULL,10);
-- 工资等级表
CREATE TABLE salarygrade (
grade INT PRIMARY KEY, -- 等级
losalary INT, -- 最低工资
hisalary INT -- 最高工资
);
-- 添加5个工资等级
INSERT INTO salarygrade(grade,losalary,hisalary) VALUES
(1,7000,12000),
(2,12010,14000),
(3,14010,20000),
(4,20010,30000),
(5,30010,99990);
c. 示例题目
-- 1.将所有员工的昵称改为大写
SELECT UCASE(nickname) FROM emp;
-- 2.显示所有员工的姓氏,截取
SELECt ename,SUBSTR(ename,1,1) FROM emp;
--- 如果客户很多复姓,可以将姓与名拆成两个字段
-- 3.显示所有员工姓名字符长度
SELECt CHAR_LENGTH(ename) FROM emp;
-- 4.显示所有员工姓名字节长度
SELECt LENGTH(ename) FROM emp;
-- 5.将所有姓李的员工,姓氏替换为li
SELECt REPLACE(ename,'李','li') FROM emp;
-- 6.将所有员工的姓名和昵称拼接在一起
SELECt CONCAT(ename,nickname) FROM emp;
2. 日期函数
a. 常用函数
-
函数:
NOW()
|CURDATE()
|CURTIME()
描述:分别获取系统当前日期和时间、日期、时间
实例:select now(); -
函数:
YEAR(DATE)
|MONTH(DATE)
|DAY(DATE)
描述:从指定日期中选择出年、月、日
实例:select year(now()); -
函数:
LAST_DAY(DATE)
描述:返回指定月份的最后一天
实例:select last_day(now()); -
函数:
ADDDATE(DATE,n)
|SUBDATE(DATE,n)
描述:计算起始日期 DATE 加(减) n 天的日期
实例:select subdate(now(),10); -
函数:
QUARTER(DATE)
描述:返回指定日期 DATE 是第几季节,返回 1 到 4
实例:select quarter(now()); -
函数:
DATEDIFF(d1,d2)
描述:计算指定日期 d1 - d2 之间相隔的天数
实例:select datediff(now(),‘1999-1-1’); -
函数:
DATE_FORMAT(d,f)
描述:按表达式 f 的要求显示日期 d
实例:select date_format(now(),’%Y-%m-%d’);
注:后面附录中有 format 可以使用的格式
b. 示例题目
-- 1.统计每个员工入职的天数
SELECT ename,DATEDIFF(NOW(),joindate) FROM emp;
-- 2.统计每个员工的工龄
SELECt ename,DATEDIFF(NOW(),joindate)/365 FROM emp;
-- 取整需要用到下一节中的数字函数
-- 3.查询2011年入职的员工
SELECt * FROM emp WHERe YEAR(joindate) = '2011';
-- 4.统计入职10年以上的员工信息
SELECt * FROM emp WHERe DATEDIFF(NOW(),joindate)/365 >10;
3. 数字函数
a. 常用函数
-
函数:
ABS(x)
描述:返回 x 的绝对值
实例:select abs(-10); -
函数:
CEIL(x)
|FLOOR(x)
描述:向上(下)取整
实例:select ceil(1.5); -
函数:
MOD(x,y)
描述:返回 x mod y 的结果,取余
实例:select mod(5,4); -
函数:
RAND()
描述:返回 0 到 1 的随机数
实例:select rand(); -
函数:
ROUND(x)
描述:四舍五入
实例:select round(1.2345); -
函数:
TRUNCATE(x,y)
(这里不是删节,是截取)
描述:返回数值 x 保留到小数点后 y 位的值
实例:select truncate(5633.123324,2);
b. 示例题目
-- 1.统计每个员工的工龄,超过半年的算一年
SELECT ename,ROUND( DATEDIFF(NOW(),joindate)/365) FROM emp;
-- 2.统计每个部门的平均薪资,保留2位小数
SELECt dept_id,TRUNCATE( AVG(salary),2 )FROM emp GROUP BY dept_id;
-- 3.统计每个部门的平均薪资,小数向上取整
SELECt dept_id,CEIL( AVG(salary) )FROM emp GROUP BY dept_id;
-- 4.统计每个部门的平均薪资,小数向下取整
SELECt dept_id,FLOOR( AVG(salary) )FROM emp GROUP BY dept_id;
4. 高级函数
a. CASE 表达式
- 相当于 Java 中 swtich 语句
i. 语法
SELECt
CASE [字段,值]
WHEN 判断条件1
THEN 希望的到的值1
WHEN 判断条件2
THEN 希望的到的值2
ELSE 前面条件都没有满足情况下得到的值
END
FROM
table_name;
ii. 示例题目
-- 查询每个员工的工资等级并排序
-- 工资等级在1显示为 '努力赚钱'
-- 工资等级在2显示为 '小康生活'
-- 工资等级在3显示为 '可以娶媳妇'
-- 工资等级在4显示为 '可以买车'
-- 工资等级在5显示为 '可以买房'
-- 工资等级不在以上列表中显示为 '土豪'
-- 思路分析:
-- 1.确定几张表
SELECt * FROM emp e INNER JOIN salarygrade sg;
-- 2.确定连接条件
SELECt * FROM emp e INNER JOIN salarygrade sg ON e.`salary` BETWEEN sg.`losalary` AND sg.`hisalary`;
-- 3.确定显示字段
SELECt e.ename,e.`salary`,sg.`grade` FROM emp e INNER JOIN salarygrade sg ON e.`salary` BETWEEN sg.`losalary` AND sg.`hisalary`;
-- 4.确定业务条件
SELECt e.ename,e.`salary`,
CASE sg.`grade`
WHEN 1 THEN '努力赚钱'
WHEN 2 THEN '小康生活'
WHEN 3 THEN '可以娶媳妇'
WHEN 4 THEN '可以买车'
WHEN 5 THEN '可以买房'
ELSE '土豪'
END AS '生活状态'
FROM emp e INNER JOIN salarygrade sg ON e.`salary` BETWEEN sg.`losalary` AND sg.`hisalary` ORDER BY sg.`grade` ASC;
b. IF 表达式
- 相当于 Java 中的三元运算符
i. 语法
SELECt IF(1 > 0,'真','假') from 表名;
ii. 示例题目
-- 工资+奖金大于20000的员工 显示家有娇妻,否则显示单身狗
SELECt ename,IF(salary+IFNULL(bonus,0) > 20000,'家有娇妻','单身狗') AS 家里有啥 FROM emp;
-- null + ∀ 都为 null
II. MySQL 函数综合案例
-- 1.计算员工的日薪(按30天),保留二位小数
SELECt ename,TRUNCATE(salary/30,2) FROM emp;
-- 2.计算出员工的年薪(12月),并且以年薪排序 降序
SELECt ename,(salary + IFNULL(bonus,0)) * 12 AS 年薪 FROM emp ORDER BY 年薪 DESC;
-- 3.找出奖金少于5000或者没有获得奖金的员工的信息
SELECt * FROM emp WHERe IFNULL(bonus,0) < 5000;
-- 4.返回员工职务名称及其从事此职务的最低工资
-- 思路分析:
-- 4.1 确定几张表
SELECt * FROM emp e INNER JOIN job j;
-- 4.2 确定连接条件
SELECt * FROM emp e INNER JOIN job j ON e.`job_id` = j.`id`;
-- 4.3 确定显示字段
SELECt j.`jname` FROM emp e INNER JOIN job j ON e.`job_id` = j.`id`;
-- 4.4 确定业务条件(分组+最低工资)
SELECt j.`jname`,MIN(e.`salary`) FROM emp e INNER JOIN job j ON e.`job_id` = j.`id` GROUP BY j.`jname`;
-- 5.返回工龄超过10年,且2月份入职的员工信息
SELECt * FROM emp WHERe DATEDIFF(NOW(),joindate)/365 > 10 AND MONTH(joindate) = 2;
-- 6.返回与 林冲 同一年入职的员工
SELECt YEAR(joindate) FROM emp WHERe ename = '林冲';
SELECt * FROM emp WHERe YEAR(joindate) = (SELECt YEAR(joindate) FROM emp WHERe ename = '林冲');
-- 7.返回每个员工的名称及其上级领导的名称(自关联)
SELECt a.`ename`,b.`ename` FROM emp a LEFT OUTER JOIN emp b ON a.`mgr` = b.`id`;
-- 8.返回工资为二等级(工资等级表)的职员名字(员工表)、部门名称(部门表)
-- 8.1 确定几张表
SELECt * FROM emp e
INNER JOIN dept d
INNER JOIN salarygrade sg;
-- 8.2 确定连接条件
SELECt * FROM emp e
INNER JOIN dept d ON e.`dept_id` = d.`id`
INNER JOIN salarygrade sg ON e.`salary` BETWEEN sg.`losalary` AND sg.`hisalary`;
-- 8.3 确定显示字段
SELECt sg.`grade`,e.`ename`,d.`dname` FROM emp e
INNER JOIN dept d ON e.`dept_id` = d.`id`
INNER JOIN salarygrade sg ON e.`salary` BETWEEN sg.`losalary` AND sg.`hisalary`;
-- 8.4 确定业务条件
SELECt sg.`grade`,e.`ename`,d.`dname` FROM emp e
INNER JOIN dept d ON e.`dept_id` = d.`id`
INNER JOIN salarygrade sg ON e.`salary` BETWEEN sg.`losalary` AND sg.`hisalary`
WHERe sg.`grade` = 2;
-- 9.涨工资:董事长2000 经理1500 其他800
-- 9.1 确定几张表和连接条件
SELECt * FROM emp e INNER JOIN job j ON e.`job_id` = j.`id`;
-- 9.2 显示字段(case表达式)
SELECt e.`ename`,j.`jname`,e.`salary` AS 涨前,
CASE j.`jname`
WHEN '董事长' THEN e.salary + 2000
WHEN '经理' THEN e.salary + 1500
ELSE e.salary + 800
END AS 涨后
FROM emp e INNER JOIN job j ON e.`job_id` = j.`id`;
III. 附录
1. 数学函数
ABS(x) 返回x的绝对值
BIN(x) 返回x的二进制(OCT返回八进制,HEX返回十六进制)
CEILING(x) 返回大于x的最小整数值
EXP(x) 返回值e(自然对数的底)的x次方
FLOOR(x) 返回小于x的最大整数值
GREATEST(x1,x2,...,xn)返回集合中最大的值
LEAST(x1,x2,...,xn) 返回集合中最小的值
LN(x) 返回x的自然对数
LOG(x,y)返回x的以y为底的对数
MOD(x,y) 返回x/y的模(余数)
PI()返回pi的值(圆周率)
RAND()返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定的值。
ROUND(x,y)返回参数x的四舍五入的有y位小数的值
SIGN(x) 返回代表数字x的符号的值
SQRT(x) 返回一个数的平方根
TRUNCATE(x,y) 返回数字x截短为y位小数的结果
2. 聚合函数
AVG(col)返回指定列的平均值
COUNT(col)返回指定列中非NULL值的个数
MIN(col)返回指定列的最小值
MAX(col)返回指定列的最大值
SUM(col)返回指定列的所有值之和
GROUP_CONCAT(col) 返回由属于一组的列值连接组合而成的结果
3. 字符串函数
ASCII(char)返回字符的ASCII码值
BIT_LENGTH(str)返回字符串的比特长度
CONCAT(s1,s2...,sn)将s1,s2...,sn连接成字符串
CONCAT_WS(sep,s1,s2...,sn)将s1,s2...,sn连接成字符串,并用sep字符间隔
INSERT(str,x,y,instr) 将字符串str从第x位置开始,y个字符长的子串替换为字符串instr,返回结果
FIND_IN_SET(str,list)分析逗号分隔的list列表,如果发现str,返回str在list中的位置
LCASE(str)或LOWER(str) 返回将字符串str中所有字符改变为小写后的结果
LEFT(str,x)返回字符串str中最左边的x个字符
LENGTH(s)返回字符串str中的字符数
LTRIM(str) 从字符串str中切掉开头的空格
POSITION(substr,str) 返回子串substr在字符串str中第一次出现的位置
QUOTE(str) 用反斜杠转义str中的单引号
REPEAT(str,srchstr,rplcstr)返回字符串str重复x次的结果
REVERSE(str) 返回颠倒字符串str的结果
RIGHT(str,x) 返回字符串str中最右边的x个字符
RTRIM(str) 返回字符串str尾部的空格
STRCMP(s1,s2)比较字符串s1和s2
TRIM(str)去除字符串首部和尾部的所有空格
UCASE(str)或UPPER(str) 返回将字符串str中所有字符转变为大写后的结果
4. 日期和时间函数
CURDATE()或CURRENT_DATE() 返回当前的日期
CURTIME()或CURRENT_TIME() 返回当前的时间
DATE_ADD(date,INTERVAL int keyword)返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECtDATE_ADD(CURRENT_DATE,INTERVAL 6 MONTH);
DATE_FORMAT(date,fmt) 依照指定的fmt格式格式化日期date值
DATE_SUB(date,INTERVAL int keyword)返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECTDATE_SUB(CURRENT_DATE,INTERVAL 6 MONTH);
DAYOFWEEK(date) 返回date所代表的一星期中的第几天(1~7)
DAYOFMONTH(date) 返回date是一个月的第几天(1~31)
DAYOFYEAR(date) 返回date是一年的第几天(1~366)
DAYNAME(date) 返回date的星期名,如:SELECT DAYNAME(CURRENT_DATE);
FROM_UNIXTIME(ts,fmt) 根据指定的fmt格式,格式化UNIX时间戳ts
HOUR(time) 返回time的小时值(0~23)
MINUTE(time) 返回time的分钟值(0~59)
MONTH(date) 返回date的月份值(1~12)
MONTHNAME(date) 返回date的月份名,如:SELECt MONTHNAME(CURRENT_DATE);
NOW() 返回当前的日期和时间
QUARTER(date) 返回date在一年中的季度(1~4),如SELECT QUARTER(CURRENT_DATE);
WEEK(date) 返回日期date为一年中第几周(0~53)
YEAR(date) 返回日期date的年份(1000~9999)
一些示例:
获取当前系统时间:SELECT FROM_UNIXTIME(UNIX_TIMESTAMP());
SELECt EXTRACT(YEAR_MONTH FROM CURRENT_DATE);
SELECt EXTRACT(DAY_SECOND FROM CURRENT_DATE);
SELECt EXTRACT(HOUR_MINUTE FROM CURRENT_DATE);
返回两个日期值之间的差值(月数):SELECt PERIOD_DIFF(200302,199802);
在Mysql中计算年龄:
SELECT DATE_FORMAT(FROM_DAYS(TO_DAYS(NOW())-TO_DAYS(birthday)),'%Y')+0 AS age FROM employee;
这样,如果Brithday是未来的年月日的话,计算结果为0。
下面的SQL语句计算员工的绝对年龄,即当Birthday是未来的日期时,将得到负值。
SELECt DATE_FORMAT(NOW(), '%Y') - DATE_FORMAT(birthday, '%Y') -(DATE_FORMAT(NOW(), '00-%m-%d') <DATE_FORMAT(birthday, '00-%m-%d')) AS age from employee
> DATE_FORMAT 可以使用的格式
格式 | 描述 |
---|---|
%a | 缩写星期名 |
%b | 缩写月名 |
%c | 月,数值 |
%D | 带有英文前缀的月中的天 |
%d | 月的天,数值(00-31) |
%e | 月的天,数值(0-31) |
%f | 微秒 |
%H | 小时 (00-23) |
%h | 小时 (01-12) |
%I | 小时 (01-12) |
%i | 分钟,数值(00-59) |
%j | 年的天 (001-366) |
%k | 小时 (0-23) |
%l | 小时 (1-12) |
%M | 月名 |
%m | 月,数值(00-12) |
%p | AM 或 PM |
%r | 时间,12-小时(hh:mm:ss AM 或 PM) |
%S | 秒(00-59) |
%s | 秒(00-59) |
%T | 时间, 24-小时 (hh:mm:ss) |
%U | 周 (00-53) 星期日是一周的第一天 |
%u | 周 (00-53) 星期一是一周的第一天 |
%V | 周 (01-53) 星期日是一周的第一天,与 %X 使用 |
%v | 周 (01-53) 星期一是一周的第一天,与 %x 使用 |
%W | 星期名 |
%w | 周的天 (0=星期日, 6=星期六) |
%X | 年,其中的星期日是周的第一天,4 位,与 %V 使用 |
%x | 年,其中的星期一是周的第一天,4 位,与 %v 使用 |
%Y | 年,4 位 |
%y | 年,2 位 |
5. 加密函数
AES_ENCRYPT(str,key) 返回用密钥key对字符串str利用高级加密标准算法加密后的结果,调用AES_ENCRYPT的结果是一个二进制字符串,以BLOB类型存储
AES_DECRYPT(str,key) 返回用密钥key对字符串str利用高级加密标准算法解密后的结果
DECODE(str,key) 使用key作为密钥解密加密字符串str
ENCRYPT(str,salt) 使用UNIXcrypt()函数,用关键词salt(一个可以惟一确定口令的字符串,就像钥匙一样)加密字符串str
ENCODE(str,key) 使用key作为密钥加密字符串str,调用ENCODE()的结果是一个二进制字符串,它以BLOB类型存储
MD5() 计算字符串str的MD5校验和
PASSWORD(str) 返回字符串str的加密版本,这个加密过程是不可逆转的,和UNIX密码加密过程使用不同的算法。
SHA() 计算字符串str的安全散列算法(SHA)校验和
示例:
SELECt ENCRYPT('root','salt');
SELECT ENCODE('xufeng','key');
SELECT DECODE(ENCODE('xufeng','key'),'key');#加解密放在一起
SELECT AES_ENCRYPT('root','key');
SELECT AES_DECRYPT(AES_ENCRYPT('root','key'),'key');
SELECT MD5('123456');
SELECT SHA('123456');
6. 控制流函数
MySQL有4个函数是用来进行条件操作的,这些函数可以实现SQL的条件逻辑,允许开发者将一些应用程序业务逻辑转换到数据库后台。
MySQL控制流函数:
CASE WHEN[test1] THEN [result1]...ELSE [default] END如果testN是真,则返回resultN,否则返回default
CASE [test] WHEN[val1] THEN [result]...ELSE [default]END 如果test和valN相等,则返回resultN,否则返回default
IF(test,t,f) 如果test是真,返回t;否则返回f
IFNULL(arg1,arg2) 如果arg1不是空,返回arg1,否则返回arg2
NULLIF(arg1,arg2) 如果arg1=arg2返回NULL;否则返回arg1
这些函数的第一个是IFNULL(),它有两个参数,并且对第一个参数进行判断。如果第一个参数不是NULL,函数就会向调用者返回第一个参数;如果是NULL,将返回第二个参数。
如:SELECT IFNULL(1,2), IFNULL(NULL,10),IFNULL(4*NULL,'false');
NULLIF()函数将会检验提供的两个参数是否相等,如果相等,则返回NULL,如果不相等,就返回第一个参数。
如:SELECT NULLIF(1,1),NULLIF('A','B'),NULLIF(2+3,4+1);
和许多脚本语言提供的IF()函数一样,MySQL的IF()函数也可以建立一个简单的条件测试,这个函数有三个参数,第一个是要被判断的表达式,如果表达式为真,IF()将会返回第二个参数,如果为假,IF()将会返回第三个参数。
如:SELECTIF(1<10,2,3),IF(56>100,'true','false');
IF()函数在只有两种可能结果时才适合使用。然而,在现实世界中,我们可能发现在条件测试中会需要多个分支。在这种情况下,MySQL提供了CASE函数,它和PHP及Perl语言的switch-case条件例程一样。
CASE函数的格式有些复杂,通常如下所示:
CASE [expression to be evaluated]
WHEN [val 1] THEN [result 1]
WHEN [val 2] THEN [result 2]
WHEN [val 3] THEN [result 3]
......
WHEN [val n] THEN [result n]
ELSE [default result]
END
这里,第一个参数是要被判断的值或表达式,接下来的是一系列的WHEN-THEN块,每一块的第一个参数指定要比较的值,如果为真,就返回结果。所有的WHEN-THEN块将以ELSE块结束,当END结束了所有外部的CASE块时,如果前面的每一个块都不匹配就会返回ELSE块指定的默认结果。如果没有指定ELSE块,而且所有的WHEN-THEN比较都不是真,MySQL将会返回NULL。
CASE函数还有另外一种句法,有时使用起来非常方便,如下:
CASE
WHEN [conditional test 1] THEN [result 1]
WHEN [conditional test 2] THEN [result 2]
ELSE [default result]
END
这种条件下,返回的结果取决于相应的条件测试是否为真。
示例:
mysql>SELECT CASE 'green'
WHEN 'red' THEN 'stop'
WHEN 'green' THEN 'go' END;
SELECT CASE 9 WHEN 1 THEN 'a' WHEN 2 THEN 'b' ELSE 'N/A' END;
SELECT CASE WHEN (2+2)=4 THEN 'OK' WHEN(2+2)<>4 THEN 'not OK' END ASSTATUS;
SELECT Name,IF((IsActive = 1),'已激活','未激活') AS RESULT FROMUserLoginInfo;
SELECt fname,lname,(math+sci+lit) AS total,
CASE WHEN (math+sci+lit) < 50 THEN 'D'
WHEN (math+sci+lit) BETWEEN 50 AND 150 THEN 'C'
WHEN (math+sci+lit) BETWEEN 151 AND 250 THEN 'B'
ELSE 'A' END
AS grade FROM marks;
SELECt IF(ENCRYPT('sue','ts')=upass,'allow','deny') AS LoginResultFROM users WHERe uname = 'sue';#一个登陆验证
7. 格式化函数
DATE_FORMAT(date,fmt) 依照字符串fmt格式化日期date值
FORMAT(x,y) 把x格式化为以逗号隔开的数字序列,y是结果的小数位数
INET_ATON(ip) 返回IP地址的数字表示
INET_NTOA(num) 返回数字所代表的IP地址
TIME_FORMAT(time,fmt) 依照字符串fmt格式化时间time值
其中最简单的是FORMAT()函数,它可以把大的数值格式化为以逗号间隔的易读的序列。
示例:
SELECT FORMAT(34234.34323432,3);
SELECT DATE_FORMAT(NOW(),'%W,%D %M %Y %r');
SELECT DATE_FORMAT(NOW(),'%Y-%m-%d');
SELECT DATE_FORMAT(19990330,'%Y-%m-%d');
SELECT DATE_FORMAT(NOW(),'%h:%i %p');
SELECT INET_ATON('10.122.89.47');
SELECT INET_NTOA(175790383);
8. 类型转化函数
为了进行数据类型转化,MySQL提供了CAST()函数,它可以把一个值转化为指定的数据类型。类型有:BINARY,CHAR,DATE,TIME,DATETIME,SIGNED,UNSIGNED
示例:
SELECT CAST(NOW() AS SIGNED INTEGER),CURDATE()+0;
SELECT 'f'=BINARY 'F','f'=CAST('F' AS BINARY);
9. 系统信息函数
DATABASE() 返回当前数据库名
BENCHMARK(count,expr) 将表达式expr重复运行count次
CONNECTION_ID() 返回当前客户的连接ID
FOUND_ROWS() 返回最后一个SELECT查询进行检索的总行数
USER()或SYSTEM_USER() 返回当前登陆用户名
VERSION() 返回MySQL服务器的版本
示例:
SELECT DATABASE(),VERSION(),USER();
SELECTBENCHMARK(9999999,LOG(RAND()PI()));#该例中,MySQL计算LOG(RAND()PI())表达式9999999次。
原文链接:https://qwert.blog.csdn.net/article/details/105915984