MySQL 常用函数的使用

目录

  • 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. 常用函数

  1. 函数:CONCAT(s1,s2...sn)
    描述:字符串 s1,s2 等多个字符串合并为一个字符串
    实例:select concat(‘Regino’,’-’,‘个人博客’);

  2. 函数:CHAR_LENGTH(str)
    描述:返回字符串 str 的字符数
    实例:select char_length(‘Hello,Regino’);

  3. 函数:LENGTH(str)
    描述:返回字符串 str 的字节数
    编码:UTF-8(一个中文字符占 3 个字节,中文标点占 3 个字节)
    实例:select length(‘你好!’);

  4. 函数:UCASE(s) | UPPER(s)
    描述:将字符串转换为大写
    实例:select ucase(‘regino’);

  5. 函数:LCASE(s) | LOWER(s)
    描述:将字符串转换为小写
    实例:select lcase(‘REGINO’);

  6. 函数:LOCATE(s1,s)
    描述:从字符串 s 中获取 s1 的开始位置
    注意:从 1 开始
    实例:select locate(‘gi’,‘regino’);(返回 3)

  7. 函数:TRIM(str) | LTRIM(str) | RTRIM(str)
    描述:字符串去空格(分别为两边、左边、右边去空格)
    实例:select trim(’ 莘莘学子 ');

  8. 函数:REPLACE(s,s1,s2)
    描述:将字符串 s2 替代字符串 s 中的字符串 s1
    实例:select replace(‘abc’,‘b’,‘x’);(输出 axc)

  9. 函数:SUBSTR(s, start, length)
    描述:从字符串 s 的 start 位置截取长度为 length 的子字符串
    注意:从 1 开始
    实例:select substr(‘regino’,‘2’,‘3’);(输出 egi)

  10. 函数: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. 常用函数

  1. 函数:NOW() | CURDATE() | CURTIME()
    描述:分别获取系统当前日期和时间、日期、时间
    实例:select now();

  2. 函数:YEAR(DATE) | MONTH(DATE) | DAY(DATE)
    描述:从指定日期中选择出年、月、日
    实例:select year(now());

  3. 函数:LAST_DAY(DATE)
    描述:返回指定月份的最后一天
    实例:select last_day(now());

  4. 函数:ADDDATE(DATE,n) | SUBDATE(DATE,n)
    描述:计算起始日期 DATE 加(减) n 天的日期
    实例:select subdate(now(),10);

  5. 函数:QUARTER(DATE)
    描述:返回指定日期 DATE 是第几季节,返回 1 到 4
    实例:select quarter(now());

  6. 函数:DATEDIFF(d1,d2)
    描述:计算指定日期 d1 - d2 之间相隔的天数
    实例:select datediff(now(),‘1999-1-1’);

  7. 函数: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. 常用函数

  1. 函数:ABS(x)
    描述:返回 x 的绝对值  
    实例:select abs(-10);

  2. 函数:CEIL(x) | FLOOR(x)
    描述:向上(下)取整
    实例:select ceil(1.5);

  3. 函数:MOD(x,y)
    描述:返回 x mod y 的结果,取余
    实例:select mod(5,4);

  4. 函数:RAND()
    描述:返回 0 到 1 的随机数
    实例:select rand();

  5. 函数:ROUND(x)
    描述:四舍五入
    实例:select round(1.2345);

  6. 函数: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将会返回NULLCASE函数还有另外一种句法,有时使用起来非常方便,如下:

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格式化日期dateFORMAT(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

你可能感兴趣的:(Database)