数据库Sql实现截取时间段和日期实例(SQL时间截取)
作者:拄杖盲学轻声码 发布时间:2024-01-27 01:38:29
【写在前面】
前些日子接到这样的需求,我们要对用户访问网站的时间做个统计,但是我想统计到具体的时间点,便于统计不同时间段(上午、下午、傍晚、凌晨)访问的人数占比。
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
来源:https://blog.csdn.net/hdp134793/article/details/128608637
猜你喜欢
- 本文实例讲述了Java实现从数据库导出大量数据记录并保存到文件的方法。分享给大家供大家参考,具体如下:数据库脚本:-- Table &quo
- 1.用一个栈【python中可以用List】就可以解决,时间和空间复杂度都是O(n)# -*- coding: utf8 -*-# 符号表S
- 平衡二叉树:在上一节二叉树的基础上我们实现,如何将生成平衡的二叉树所谓平衡二叉树:我自己定义就是:任何一个节点的左高度和右高度的差的绝对值都
- 本文实例为大家分享了OpenCV实现直线检测的具体代码,供大家参考,具体内容如下1 介绍本文主要介绍OpenCV自带的直线检测函数Hough
- 适用环境: PHP5.2.x / mysql 5.0.xclass Mysql { priva
- 本文实例讲述了python实现连接mongodb的方法。分享给大家供大家参考。具体分析如下:通过pymongo可以很容易的链接到mongod
- 几乎每个程序都需要用到图片,在小程序中我们可以通过image组件显示图片。当然小程序也是可以上传图片的,微信小程序文档也写的很清楚。上传图片
- 本文实例讲述了python中元类用法,分享给大家供大家参考。具体方法分析如下:1.元类(metaclass)是用来创建类的类2.type(o
- 如下所示:# -*- coding: utf-8 -*-# 要求:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。def
- 如下所示:#利用小波分析进行特征分析#参数初始化inputfile= 'C:/Users/Administrator/Desktop
- 对于Linux用户而言,命令行操作我们已经非常熟悉了。与其他流行的操作系统不同,在Linux社区中,使用命令行与使用图形用户界面执行类似任务
- 目录技术背景diagrams的安装基础逻辑关系图组件簇的定义总结概要技术背景对于一个架构师或者任何一个软件工程师而言,绘制架构图都是一个比较
- 题目描述这篇博文是数字图像处理的大作业. 题目描述:给定40张不同风格的纹理图片,大小为512*512,要求将每张图片分为大小相同的9块,利
- 1、重装后启动mysql服务,提示 本地计算机无法启动 mysql 服务 错误 1067:进程意外终止。2、查看mysql根目录下有一 计算
- 简单的一个python日志处理类#/usr/bin/python#coding=utf-8import time,typesclass lo
- 本文为大家分享了如何用Navicat把csv数据导入mysql,供大家参考,具体内容如下1.获取csv数据,用office另存为功能把exc
- 前提搭建钉钉应答机器人,需要先准备或拥有以下权限:钉钉企业的管理员或子管理员(如果不是企业管理员,可以自己创建一个企业,很方便的)有公网通信
- 具体代码如下所示:import numpy as npfrom matplotlib import pyplot as pltfrom sc
- ACCESS数据库中Field对象的caption属性(也就是标题)是用来设置数据字段的标题,在正常的数据库设计中为了保持维护的便利性,许多
- 以前写过《 10条影响CSS渲染速度的写法与建议》,今天放些数据出来,供参考;首先说明一点,CSS对网页的最后渲染出来的速度影响非