函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数: 函数:目录
I. MySQL 常用函数
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. 导入数据
-- 多表案例 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 表达式
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 表达式
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次。
本网页所有视频内容由 imoviebox边看边下-网页视频下载, iurlBox网页地址收藏管理器 下载并得到。
ImovieBox网页视频下载器 下载地址: ImovieBox网页视频下载器-最新版本下载
本文章由: imapbox邮箱云存储,邮箱网盘,ImageBox 图片批量下载器,网页图片批量下载专家,网页图片批量下载器,获取到文章图片,imoviebox网页视频批量下载器,下载视频内容,为您提供.
阅读和此文章类似的: 全球云计算