0


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

【写在前面】前些日子接到这样的需求,我们要对用户访问网站的时间做个统计,但是我想统计到具体的时间点,便于统计不同时间段(上午、下午、傍晚、凌晨)访问的人数占比。

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

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'ORDERBY 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

本文转载自: https://blog.csdn.net/hdp134793/article/details/128608637
版权归原作者 拄杖盲学轻声码 所有, 如有侵权,请联系我们删除。

“【SQL时间截取】数据库Sql实现截取时间段和日期”的评论:

还没有评论