日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

【SQL时间截取】数据库Sql实现截取时间段和日期

發布時間:2023/12/31 数据库 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【SQL时间截取】数据库Sql实现截取时间段和日期 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

【寫在前面】前些日子接到這樣的需求,我們要對用戶訪問網站的時間做個統計,但是我想統計到具體的時間點,便于統計不同時間段(上午、下午、傍晚、凌晨)訪問的人數占比。

數據庫Sql實現截取時間段和日期

  • 1、原始數據查看
  • 2、 sql實現日期和時間點分離(基于MySQL)
  • 3、SQL語句及應用場景
    • A、獲取不同時間段的數據(%T和%H:%i:%s效果一樣)
    • B、獲取日期,不包括時間點(%Y%m%d)
    • C、獲取是幾幾年的第幾周(%X%V)
  • 4、邀您入皇榜

1、原始數據查看

那么首先給大家看一下數據表的原始數據:

select id,time,count from bf_visited_address;


由此可見這個時間字段是把日期和時分秒都揉在一起了,但是我只想通過時分秒來判斷不同時間段的訪問統計,那么我們寫sql的時候需要稍加調整了。

2、 sql實現日期和時間點分離(基于MySQL)

核心方法是:DATE_FORMAT() 函數,這個函數主要用于不同格式的時間/日期數據
使用語法:DATE_FORMAT(date,format)
date:表示您待處理的時間值,也就是你在數據庫表中展示的字段;
format:表示您要使用的格式,這個有專門約定的格式,具體的我帶您羅列一下,如下所示
常用的我放在最前面。

常用格式(年月日時分秒:%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月,數值(00-12)%c月,數值(1-12)
%d日,數值(00-31)%e日,數值(0-31)
%H小時 (00-23)%h或%I小時 (01-12)
%i分鐘,數值(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、獲取不同時間段的數據(%T和%H:%i:%s效果一樣)

先轉化成HH:mm:ss格式

select id,time,count, DATE_FORMAT(time,'%H:%i:%s') as detailTime from bf_visited_address;


添加時間過濾條件(過濾條件后面你可以隨便修改)

select * from (select id,time,count, DATE_FORMAT(time,'%T') as detailTime from bf_visited_address) tss where tss.detailTime>'00:00:00' and tss.detailTime<'09:00:00' ORDER BY tss.detailTime asc;

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做一個整合即可實現,如下代碼及效果:

select bf_visited_address.*, DATE_FORMAT(time,'%X年第%V周') as detailTime from bf_visited_address;

4、邀您入皇榜

每個屬性和格式我都在數據庫里面親自嘗試過,都是OK的,創作路上有您的支持,我相信能走的更遠更輕松,喜歡博主的話可以給個支持哈!
博主特備皇榜,等您來上!
皇榜入口點擊此處

總結

以上是生活随笔為你收集整理的【SQL时间截取】数据库Sql实现截取时间段和日期的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。