函数总结:
常见函数:
字符函数:
length
concat
substr
instr
trim
upper
lower
lpad
rpad
replace
数学函数:
round
ceil
floor
truncate
mod
日期函数:
now
curdate
year
month
monthname
day
hour
minute
second
其他函数:
version
database
user
控制函数
if
case
#四、其他函数
SELECT VERSION();
SELECT DATABASE();
SELECT USER();
#五、流程控制函数
#1.if函数:if else 的效果
SELECT IF(10 > 5, '大', '小'); #类似三目运算符
SELECT
last_name,
commission_pct,
IF(commission_pct IS NULL,'没奖金,呵呵','有奖金,嘻嘻') 备注
FROM
employees;
#2.case函数使用:类似switch case 的效果
/*
case 要判断的字段或者表达式
when 常量1 then 要显示的值1或语句1;
when 常量2 then 要显示的值2或语句2;
...
else 要显示的值n或语句n
end
*/
/*案例:查询员工的工资,要求
部门编号=30,显示的工资为1.1倍
部门编号=30,显示的工资为1.1倍
部门编号=30,显示的工资为1.1倍
其他部门,显示的工资为原工资
*/
SELECT salary 原始工资,department_id,
CASE department_id
WHEN 30 THEN salary*1.1
WHEN 40 THEN salary*1.2
WHEN 50 THEN salary*1.3
ELSE salary
END AS 薪水
FROM employees;
#3.case 函数的使用二:类似多重if
/*
case
when 条件1 then 要显示的值1或语句1;
when 条件2 then 要显示的值2或语句2;
...
else 要显示的值n或语句n
end
*/
#案例:查询员工的工资情况
#如果工资>20000,显示A级别
#如果工资>15000,显示B级别
#如果工资>10000,显示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;