sql学习-01

提示:sql学习之路,主要包含ROUND,TIMESTAMPDIFF,IFNULL,以及CASE WHEN函数的用法。


1. ROUND函数

1.1 ROUND() 函数用于把数值字段舍入为指定的小数位数。
1.2 SQL ROUND() 语法

SQL ROUND() 函数

SELECT ROUND(column_name,decimals) FROM TABLE_NAME;

ROUND函数的参数介绍

2. TIMESTAMPDIFF函数

MySQL计算两个日期相差的天数、月数、年数

MySQL TIMESTAMPDIFF函数简介

TIMESTAMPDIFF(unit,begin,end); 

3. IFNULL() 函数

MySQL中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;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值