【SQL时间截取】数据库Sql实现截取时间段和日期
【寫在前面】前些日子接到這樣的需求,我們要對用戶訪問網(wǎng)站的時間做個統(tǒng)計,但是我想統(tǒng)計到具體的時間點,便于統(tǒng)計不同時間段(上午、下午、傍晚、凌晨)訪問的人數(shù)占比。
數(shù)據(jù)庫Sql實現(xiàn)截取時間段和日期
- 1、原始數(shù)據(jù)查看
- 2、 sql實現(xiàn)日期和時間點分離(基于MySQL)
- 3、SQL語句及應用場景
- A、獲取不同時間段的數(shù)據(jù)(%T和%H:%i:%s效果一樣)
- B、獲取日期,不包括時間點(%Y%m%d)
- C、獲取是幾幾年的第幾周(%X%V)
- 4、邀您入皇榜
1、原始數(shù)據(jù)查看
那么首先給大家看一下數(shù)據(jù)表的原始數(shù)據(jù):
select id,time,count from bf_visited_address;
由此可見這個時間字段是把日期和時分秒都揉在一起了,但是我只想通過時分秒來判斷不同時間段的訪問統(tǒng)計,那么我們寫sql的時候需要稍加調(diào)整了。
2、 sql實現(xiàn)日期和時間點分離(基于MySQL)
核心方法是:DATE_FORMAT() 函數(shù),這個函數(shù)主要用于不同格式的時間/日期數(shù)據(jù)
使用語法:DATE_FORMAT(date,format)
date:表示您待處理的時間值,也就是你在數(shù)據(jù)庫表中展示的字段;
format:表示您要使用的格式,這個有專門約定的格式,具體的我?guī)_列一下,如下所示
常用的我放在最前面。
常用格式(年月日時分秒:%Y-%m-%D %H:%i:%s)
| %T | 時間, 24-小時 (hh:mm:ss) | %r | 時間,12-小時(hh:mm:ss AM 或 PM) |
| %Y | 年,4 位(2023) | %y | 年,2 位(23) |
| %m | 月,數(shù)值(00-12) | %c | 月,數(shù)值(1-12) |
| %d | 日,數(shù)值(00-31) | %e | 日,數(shù)值(0-31) |
| %H | 小時 (00-23) | %h或%I | 小時 (01-12) |
| %i | 分鐘,數(shù)值(00-59) | %f | 微秒 |
| %s | 秒(00-59) | %S | 秒(00-59) |
不常用格式(幾幾年第幾周:%X年 第%V周)
| %W | 星期名(Thursday) | %w | 周的天 (0=星期日, 6=星期六) |
| %a | 縮寫星期名(Thu) | ||
| %M | 月名(December) | %b | 縮寫月名(Dec) |
| %U | 周 (00-53) 星期日是一周的第一天 | %u | 周 (00-53) 星期一是一周的第一天 |
| %V | 周 (01-53) 星期日是一周的第一天,與 %X 使用 | %v | 周 (01-53) 星期一是一周的第一天,與 %x 使用 |
| %X | 年,其中的星期日是周的第一天,4 位,與 %V 使用 | %x | 年,其中的星期一是周的第一天,4 位,與 %v 使用 |
3、SQL語句及應用場景
A、獲取不同時間段的數(shù)據(jù)(%T和%H:%i:%s效果一樣)
先轉(zhuǎn)化成HH:mm:ss格式
select id,time,count, DATE_FORMAT(time,'%H:%i:%s') as detailTime from bf_visited_address;
添加時間過濾條件(過濾條件后面你可以隨便修改)
B、獲取日期,不包括時間點(%Y%m%d)
select id,time,count, DATE_FORMAT(time,'%Y-%m-%d') as detailTime from bf_visited_address;C、獲取是幾幾年的第幾周(%X%V)
給一個時間點,sql獲取哪一年的第幾周,此時將%X和%V做一個整合即可實現(xiàn),如下代碼及效果:
select bf_visited_address.*, DATE_FORMAT(time,'%X年第%V周') as detailTime from bf_visited_address;4、邀您入皇榜
每個屬性和格式我都在數(shù)據(jù)庫里面親自嘗試過,都是OK的,創(chuàng)作路上有您的支持,我相信能走的更遠更輕松,喜歡博主的話可以給個支持哈!
博主特備皇榜,等您來上!
皇榜入口點擊此處
總結(jié)
以上是生活随笔為你收集整理的【SQL时间截取】数据库Sql实现截取时间段和日期的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: .net生鲜超市销售系统
- 下一篇: 在Grails 2.3.X中使用sass