数据库Sql实现截取时间段和日期实例(SQL时间截取)

 更新时间:2023年05月29日 10:18:37   作者:拄杖盲学轻声码  
在许多情况下你也许只想得到日期和时间的一部分,而不是完整的日期和时间,下面这篇文章主要给大家介绍了关于数据库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' 
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;

补充:sql截取日期/时间的单独部分,比如年、月、日、小时、分钟等等

可以使用EXTRACT() 函数。(oracle和mysql都有该函数)

语法:

EXTRACT(unit FROM date)

date 参数是合法的日期表达式。unit 参数可以是下列的值:

YEAR\MONTH\WEEK\DAY\HOUR\MINUTE\SECOND (这里只列出部分常用值)

上面依次代表:年、月、周、日、时、分、秒

示例:table 表id为1的数据有一个日期类型的字段 createDate 值为 2019-11-12 10:12:33

select
EXTRACT(YEAR FROM createDate) as createYear,
EXTRACT(MONTH FROM createDate) as createMonth,
EXTRACT(DAY FROM createDate) as createDay from table where id = 1

结果:

createYear -- 2019
createMonth -- 11
createDay  -- 12

总结

到此这篇关于数据库Sql实现截取时间段和日期的文章就介绍到这了,更多相关Sql截取时间段和日期内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL5.7.18主从复制搭建(一主一从)教程详解

    MySQL5.7.18主从复制搭建(一主一从)教程详解

    MySQL使用3个线程来执行复制功能(其中1个在主服务器上,另两个在从服务器上。这篇文章主要介绍了MySQL5.7.18主从复制搭建(一主一从)教程详解,需要的朋友可以参考下
    2017-08-08
  • MySQL 8.0.35数据库下载安装以及环境变量的配置方法

    MySQL 8.0.35数据库下载安装以及环境变量的配置方法

    很多朋友刚开始接触mysql数据库服务器,这篇文章主要给大家介绍了关于MySQL 8.0.35数据库下载安装以及环境变量的配置方法,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • MySQL入门完全指南及Linux系统下基本的安装教程

    MySQL入门完全指南及Linux系统下基本的安装教程

    这篇文章主要介绍了MySQL入门完全指南及Linux系统下基本的安装教程,对MySQL的基本特性有一个较为详细的整理,需要的朋友可以参考下
    2015-11-11
  • 关于避免MySQL替换逻辑SQL的坑爹操作详解

    关于避免MySQL替换逻辑SQL的坑爹操作详解

    这篇文章主要给大家介绍了关于避免MySQL替换逻辑SQL的坑爹操作的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-03-03
  • 关于Mysql提高SQL性能的技巧(必看)

    关于Mysql提高SQL性能的技巧(必看)

    这篇文章主要介绍了关于Mysql提高SQL性能的技巧(必看),SQL查询的性能直接影响系统的响应时间,优化SQL可以减少查询的执行时间,提高系统的响应速度,提升用户体验,本文就来详细讲解一下如何优化SQL性能
    2023-07-07
  • MySQL将多行数据转换为一行数据的实现示例

    MySQL将多行数据转换为一行数据的实现示例

    在MySQL中,GROUP_CONCAT函数可以将多个记录的列值连接成一个字符串,适用于将多行数据合并为单行显示,本文就来详细的介绍一下,感兴趣的可以了解一下
    2024-09-09
  • mysql中根据已有的表来创建新表的三种方式(最新推荐)

    mysql中根据已有的表来创建新表的三种方式(最新推荐)

    这篇文章主要介绍了mysql中根据已有的表来创建新表的三种方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • mysql insert if not exists防止插入重复记录的方法

    mysql insert if not exists防止插入重复记录的方法

    在 MySQL 中,插入(insert)一条记录很简单,但是一些特殊应用,在插入记录前,需要检查这条记录是否已经存在,只有当记录不存在时才执行插入操作,本文介绍的就是这个问题的解决方案。
    2011-04-04
  • MySQL中触发器的基础学习教程

    MySQL中触发器的基础学习教程

    这篇文章主要介绍了MySQL中触发器的基础学习教程,包括对触发器的创建和管理等基本知识,着力推荐!需要的朋友可以参考下
    2015-12-12
  • MySql允许远程连接如何实现该功能

    MySql允许远程连接如何实现该功能

    这篇文章主要介绍了 MySql允许远程连接如何实现该功能的相关资料,需要的朋友可以参考下
    2017-02-02

最新评论