MySQL日期及时间字段怎么查询

1.日期和时间类型概览

%ign%ignore_a_1%re_a_1%支持的日期和时间类型有 datetime、timestamp、date、time、year ,

几种类型比较如下:

MySQL日期及时间字段怎么查询

涉及到日期和时间字段类型选择时,根据存储需求选择合适的类型即可。

2.日期和时间相关函数

处理日期和时间字段的函数有很多,有的经常会在查询中使用到,

下面介绍下几个相关函数的使用方法:

CURDATE 和 CURRENT_DATE 两个函数作用相同,返回当前系统的日期值。

CURTIME 和 CURRENT_TIME 两个函数作用相同,返回当前系统的时间值。

NOW() 和 SYSDATE() 两个函数作用相同,返回当前系统的日期和时间值。

UNIX_TIMESTAMP 获取UNIX时间戳函数,返回一个以 UNIX 时间戳为基础的无符号整数。

FROM_UNIXTIME 将 UNIX 时间戳转换为时间格式,与UNIX_TIMESTAMP互为反函数。

TO_DAYS() 提取日期值并返回自公元0年到现在的天数。

DAY() 获取指定日期或时间中的天值。

DATE() 获取指定日期或时间中的日期。

TIME() 获取指定日期或时间中的时间。

MONTH 获取指定日期中的月份。

WEEK 获取指定日期是一年中的第几周。

YEAR 获取年份。

Soundful Soundful

Soundful Ai音乐生成器,只需一个按钮即可生成免版税曲目

Soundful 240 查看详情 Soundful

QUARTER 获取日期所在的季度值。

DATE_ADD 和 ADDDATE 两个函数功能相同,都是向日期添加指定的时间间隔。

DATE_SUB 和 SUBDATE 两个函数功能相同,都是向日期减去指定的时间间隔。

ADDTIME 时间加法运算,在原始时间上添加指定的时间。

SUBTIME 时间减法运算,在原始时间上减去指定的时间。

DATEDIFF 获取两个日期之间间隔,返回参数 1 减去参数 2 的值。

DATE_FORMAT 格式化指定的日期,根据参数返回指定格式的值。

一些使用示例:

mysql> select CURRENT_DATE,CURRENT_TIME,NOW();+--------------+--------------+---------------------+| CURRENT_DATE | CURRENT_TIME | NOW()               |+--------------+--------------+---------------------+| 2020-06-03   | 15:09:37     | 2020-06-03 15:09:37 |+--------------+--------------+---------------------+mysql> select TO_DAYS('2020-06-03 15:09:37'),TO_DAYS('2020-06-03')-TO_DAYS('2020-06-01');+--------------------------------+---------------------------------------------+| TO_DAYS('2020-06-03 15:09:37') | TO_DAYS('2020-06-03')-TO_DAYS('2020-06-01') |+--------------------------------+---------------------------------------------+|                         737944 |                                           2 |+--------------------------------+---------------------------------------------+mysql> select MONTH('2020-06-03'),WEEK('2020-06-03'),YEAR('2020-06-03');+---------------------+--------------------+--------------------+| MONTH('2020-06-03') | WEEK('2020-06-03') | YEAR('2020-06-03') |+---------------------+--------------------+--------------------+|                   6 |                 22 |               2020 |+---------------------+--------------------+--------------------+# DATEDIFF(date1,date2) 返回起始时间 date1 和结束时间 date2 之间的天数mysql> SELECT DATEDIFF('2017-11-30','2017-11-29') AS COL1,    -> DATEDIFF('2017-11-30','2017-12-15') AS col2;+------+------+| COL1 | col2 |+------+------+|    1 |  -15 |+------+------+

3.日期和时间字段的规范查询

为满足我们的查询需求做好准备,项目需求通常涉及基于日期或时间的条件筛选查询。下面我们来探讨如何查询和筛选日期和时间字段,因为这类需求是多种多样的。

首先,为了使查询更加准确,在插入数据时也要按规范来插入。为了确保年份使用4位数字且日期和月份在合理范围内,我们创建了一个表并插入了部分数据以方便测试。

CREATE TABLE `t_date` (`increment_id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '自增主键',`year_col` YEAR NOT NULL  COMMENT '年',`date_col` date NOT NULL  COMMENT '日期',`time_col` time NOT NULL  COMMENT '时间',`dt_col` datetime NOT NULL  COMMENT 'datetime时间',`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',  PRIMARY KEY (`increment_id`)) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COMMENT='time测试表';# 日期和时间都选取当前的日期或时间INSERT INTO t_date (year_col,date_col,time_col,dt_col,create_time) VALUES (year(now()),DATE(NOW()),time(now()),NOW(),NOW());# 指定日期或时间插入INSERT INTO t_date ( `year_col`, `date_col`, `time_col`, `dt_col`, `create_time` )VALUES    ( 2020, '2020-06-03', '09:00:00', '2020-06-03 10:04:04', '2020-06-03 10:04:04' ),    ( 2020, '2020-05-10', '18:00:00', '2020-05-10 16:00:00', '2020-05-10 16:00:00' ),    ( 2019, '2019-10-03', '16:04:04', '2019-10-03 16:00:00', '2019-10-03 16:00:00' ),    ( 2018, '2018-06-03', '16:04:04', '2018-06-03 16:00:00', '2018-06-03 16:00:00' ),    ( 2000, '2000-06-03', '16:04:04', '2000-06-03 08:00:00', '2000-06-03 08:00:00' ),    ( 2008, '2008-06-03', '16:04:04', '2008-06-03 08:00:00', '2008-06-03 08:00:00' ),    ( 1980, '1980-06-03', '16:04:04', '1980-06-03 08:00:00', '1980-06-03 08:00:00' );

根据上面测试表的数据,我们来学习下几种常见查询语句的写法:

根据日期或时间等值查询:

select * from t_date where year_col = 2020;select * from t_date where date_col = '2020-06-03';select * from t_date where dt_col = '2020-06-03 16:04:04';

根据日期或时间范围查询:

select * from t_date where date_col > '2018-01-01';select * from t_date where dt_col >= '2020-05-01 00:00:00' and dt_col < '2020-05-31 23:59:59';select * from t_date where dt_col between '2020-05-01 00:00:00' and  '2020-05-31 23:59:59';

查询本月的数据:

# 查询create_time在本月的数据select * from t_date where DATE_FORMAT(create_time, '%Y-%m' ) = DATE_FORMAT( CURDATE( ) , '%Y-%m' );

查询最近多少天的数据:

# 以date_col为条件 查询最近7天或30天的数据SELECT * FROM t_date where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(date_col);SELECT * FROM t_date where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(date_col);

其他各类查询写法:

# 查询今天的数据SELECT * FROM t_date WHERE TO_DAYS(create_time) = TO_DAYS(NOW());# 查询某个月的数据SELECT * FROM t_date WHERE DATE_FORMAT(create_time, '%Y-%m')='2020-06';# 查询某年的数据SELECT * FROM t_date WHERE DATE_FORMAT(create_time, '%Y')= 2020;SELECT * FROM t_date WHERE YEAR(create_time) = 2020;# 根据日期区间查询数据,并排序SELECT * FROM t_date WHERE DATE_FORMAT(create_time, '%Y') BETWEEN '2018' AND '2020' ORDER BY create_time DESC;

以上就是MySQL日期及时间字段怎么查询的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/759124.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月26日 00:15:38
下一篇 2025年11月26日 00:16:54

相关推荐

  • 您应该在 5 年内使用的 PHP 功能

    PHP在2025年及以后仍将是Web开发的核心技术。PHP 8.x版本带来了革命性的改进,使其更强大、更高效、更易于使用。本教程将介绍PHP 8.x中一些值得关注的功能,帮助您构建可靠、面向未来的应用程序。 JIT (即时) 编译:性能飞跃 JIT编译器是PHP 8.x最显著的改进之一。它通过在运行…

    好文分享 2025年12月11日
    000
  • 像对待对象一样使用变量

    本文仅代表个人观点,不构成任何建议。 Ruby和JavaScript等语言的一个吸引人的特性是其变量作为对象处理的方式。这种设计在某些情况下提升了代码可读性,但在另一些情况下则并非如此。 例如: # Ruby程序,演示length方法str = “hello, world!”puts str.len…

    2025年12月11日
    000
  • 如何在 Laravel 中为多种资源构建通用 CRUD 控制器

    Laravel 通用 CRUD 控制器:高效管理多种资源 在 Laravel 应用中,管理多个资源的 CRUD 操作可能变得复杂,尤其当模型数量不断增加时。本文将指导您构建一个通用的 CRUD 控制器,以便在一个控制器中高效处理所有现有的和未来的 CRUD 操作。 为何选择通用控制器? 通用控制器带…

    2025年12月11日
    000
  • PHP 8如何防范SQL注入

    PHP 8 提供了多个防御 SQL 注入的方法:参数化查询、PDO 强化功能和输入验证过滤。参数化查询将 SQL 查询和数据分开处理,防止恶意代码执行。 PDO 具有数据类型检查、错误处理和跨数据库兼容性。输入验证过滤在使用参数化查询前检查用户输入,去除恶意代码。结合这几种方法,构建多层防御体系,保…

    2025年12月11日
    000
  • PHP 框架:需要避免的隐藏错误

    Symfony (本文撰写时版本为7.2) 和 Laravel 等框架高度灵活,鼓励最佳实践,但仍可能出现设计、安全或性能问题。 Symfony:避免直接调用 $container 错误示范:直接在控制器中使用 $container 获取依赖项。 class LuckyController exte…

    2025年12月11日
    000
  • 探索 Laravel 目录结构的一天

    Laravel,这个优雅的PHP框架,旨在简化现代Web应用的开发。新建Laravel项目时,自带的清晰目录结构鼓励最佳实践,并实现明确的关注点分离。让我们深入了解其主要目录及用途。 Laravel 目录结构详解 一个标准Laravel安装包含以下核心目录: 项目根目录/|– app/|– bo…

    2025年12月11日
    000
  • Lithe SwissHelper 简介:简化 PHP 开发

    Lithe SwissHelper:您的PHP开发助手 Lithe SwissHelper是一个轻量级、功能强大的PHP实用程序库,旨在简化您的日常开发工作。它提供了一套全面的工具,涵盖字符串处理、数组操作、数据验证、日期时间处理、货币格式化以及URL操作等常见任务,帮助您编写更简洁、高效和易于维护…

    2025年12月11日
    000
  • 本地开发之战:ServBay 与 MAMP

    mamp 和 servbay:本地服务器解决方案深度对比 MAMP 和 ServBay 都是优秀的本地服务器搭建工具,但它们各有千秋。本文将深入比较两者的功能、优缺点,帮助您选择最合适的工具。 MAMP 与 ServBay 的核心差异 本地服务器对于简化开发流程至关重要,MAMP 作为一款成熟的工具…

    2025年12月11日 好文分享
    000
  • 如何选择合适的PHP 8开发工具?

    PHP 8開發工具選擇取決於項目規模和個人偏好。主流選項包括:程式碼編輯器/IDE:VS Code:免費、輕量級、可擴展,適合各種平台。PHPStorm:強大的功能集,但收費且資源需求高。Sublime Text:輕量級、自訂性高,可用於簡單的PHP開發。除錯工具:Xdebug:配合VS Code或…

    2025年12月11日
    000
  • 如何安装Nginx服务器并配置PHP 8?

    Nginx与PHP 8集成指南安装Nginx:使用apt软件包管理器(Ubuntu示例)。安装PHP 8:使用ppa源和apt软件包管理器(Ubuntu示例)。配置Nginx:添加location块处理PHP文件(根据系统路径修改socket)。测试配置文件并重启Nginx。定位问题:检查Nginx…

    2025年12月11日
    000
  • 如何配置PHP 8的扩展?

    如何配置 PHP 8 扩展?确认 PHP 配置文件 (php.ini) 位置。找到并更新 extension_dir 指令,指定扩展文件目录。通过在 php.ini 中添加 extension= 开头的行来启用扩展。保存 php.ini 并重启 Web 服务器或 PHP-FPM。 如何配置PHP 8…

    2025年12月11日
    000
  • 如何配置PHP 8的数据库连接?

    如何配置PHP 8数据库连接?掌握以下关键要点:选择PDO扩展: 推荐使用PDO,它更抽象、更灵活。设置DSN: 包含数据库信息,如主机、数据库名和字符集 (建议使用utf8mb4)。启用错误抛出: 使用PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION 来…

    2025年12月11日
    000
  • 如何配置PHP 8的时区?

    PHP 8的时区配置主要依靠php.ini和源码。在源码中,使用date_default_timezone_set()函数设置时区,需指定准确的时区标识符。若使用DateTimeZone类,则可更精细地控制时区。常见错误包括忘记设置时区或使用错误的标识符,可通过date_default_timezo…

    2025年12月11日
    000
  • PHP7和PHP8的数据库支持差异

    PHP7和PHP8的数据库支持相比,PHP8在性能上大幅提升,执行速度提升~20%,预处理语句效率更高;还提供了异步操作等高级特性。但升级时要注意数据库驱动程序兼容性和代码修改,使用预处理语句防止SQL注入漏洞至关重要。 PHP7和PHP8的数据库支持:进化还是革命? 你可能在想,PHP7和PHP8…

    2025年12月11日
    000
  • PHP 书籍推荐

    php 和 mysql 学习资源推荐:从入门到高级 本文推荐一系列 PHP 和 MySQL 学习书籍,涵盖不同技能水平,从初学者到高级开发者都能找到合适的学习资料。 初学者 PHP 和 MySQL:忍者新手: 这本书专为初学者设计,重点讲解如何构建 Web 项目,并涵盖数据库实践、安全性和数据操作。…

    2025年12月11日 好文分享
    000
  • 如何部署PHP 8应用程序?

    部署 PHP 8 应用程序涉及以下步骤:选择 Linux 服务器并安装 PHP 8 和扩展。安装 Apache 或 Nginx 网络服务器。仔细配置 PHP 配置文件 (php.ini)。审查代码是否存在硬编码路径和环境变量依赖。使用版本控制(例如 Git)管理代码。实施自动化部署流程(例如 Ans…

    2025年12月11日
    000
  • 如何在 Ubuntu 上安装 PHP

    PHP 代表超文本预处理器,它是一种基于脚本的服务器端编程语言。PHP 有助于自动化各种服务器任务。它处理动态内容、数据库请求和数据预处理/显示等任务。 安装 PHP Ubuntu 像许多开发工具一样,PHP 有几个不同的版本 版本。在撰写本文时,PHP 7.4。和 8.1 是当前 支持和最常用的软…

    2025年12月11日 好文分享
    000
  • PHP7和PHP8的数组操作差异

    PHP8的数组操作引入性能优化、更简洁灵活的语法和新增特性,包括:遍历数组时内存访问次数减少,性能提升,尤其在处理大型数组时。str_contains()函数优雅地检查字符串是否包含子串,处理数组元素更方便。命名参数提高代码可读性,尤其当函数参数较多时。match表达式更灵活地处理数组元素,减少代码…

    2025年12月11日
    000
  • Sublime Text Config for Laravel

    本文档介绍了笔者使用 Sublime Text 编辑器进行 Laravel 应用开发时的配置方案。 插件 以下插件显著提升了开发效率: GitBlameGitGutterAdvancedNewFileSyncSideBarLSPLSP-intelephenseLSP-bashLSP-dockerfi…

    2025年12月11日
    000
  • 如何选择合适的Web服务器?

    选择Web服务器时,关键在于应用场景,根据流量、并发量等需求选择合适软件。基础服务器软件包括Apache、Nginx、IIS,各有特点。Nginx轻量级,适合静态资源和反向代理,Apache配置灵活。高并发、高流量网站可考虑负载均衡技术或性能更强大的服务器软件,如Apache。性能调优、安全配置也不…

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信