提示:sql学习之路,主要包含ROUND,TIMESTAMPDIFF,IFNULL,以及CASE WHEN函数的用法。
1. ROUND函数
1.1 ROUND() 函数用于把数值字段舍入为指定的小数位数。
1.2 SQL ROUND() 语法
SELECT ROUND(column_name,decimals) FROM TABLE_NAME;
2. TIMESTAMPDIFF函数
TIMESTAMPDIFF(unit,begin,end);
3. IFNULL() 函数
IFNULL() 函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。
IFNULL(expression, alt_value)
如果第一个参数的表达式 expression 为 NULL,则返回第二个参数的备用值。
4. CASE WHEN用法详解
CASE WHEN 用法详解
sql中case when的用法
Case具有两种格式:简单Case函数和Case搜索函数
4.1:简单Case函数
case sex
when '1' then '男'
when '2' then '女'
else '其他' end
4.2:case搜索函数
case
when sex = '1' then '男'
when sex = '2' then '女'
else '其他' end
5. 示例
# SELECT TIMESTAMPDIFF(YEAR, '2018-01-01', '2018-06-01') result;
# MICROSECOND\SECOND\MINUTE\HOUR\DAY\WEEK\MONTH\QUARTER\YEAR
# 以天为单位,计算实际工作时长
SELECT ROUND(
TIMESTAMPDIFF(
HOUR, t.start, t.end_time
)/24
,2) totalTime, NOW() `now` FROM dy_time AS t;
# 以天为单位,计算超期时长
SELECT ROUND(
TIMESTAMPDIFF(
HOUR, t.plan_end_time, NOW()
)/24
,2) overTime, NOW() `now` FROM dy_time AS t;
# MYSQL IFNULL(expr1,expr2)
# 如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2。IFNULL()返回一个数字或字符串值,取决于它被使用的上下文环境。
SELECT IFNULL(t.end_time, NOW()) en_now FROM dy_time AS t;
# case when 的用法
SELECT *,
(
CASE
WHEN num < 0 THEN 9
WHEN num >= 0 THEN 99
END
) AS dd
FROM dy_time;
# orderby 用法,有时候可以借助筛选的方法对数据库的字段进行排序
SELECT * FROM dy_time WHERE num <= 0;