mysql查询今天日期
一、需求描述在业务开发的查询mysql数据库过程中,常常需要查询类似于今天、明天、昨天的数据,或者对日期进行加减计算,比如对某个日期加上几天、几个小时等操作的。在此情况下,我们可以使用date_add...
2024.11.13今天我们把知识的焦点投向数据库方面,因为数据库是应用程序的基石,是一切生产的动力。先说一个小小的知识点,在存储日期时间时,应该选用 timestamp 时间戳类型,还是应该用 datettime 类型?
两者有何不同,效率如何,以及各自的优劣。
学习时间MySQL中的 timestamp 通常用于跟踪记录的更改,并且通常在每次记录更改时进行更新。如果要存储特定值,则应使用 datetime 字段。
如果你在这两者之间犹豫不决,那就请优先使用时间戳。MySQL中提供了内置的函数用于时间,日期格式转换和计算,使用起来非常方便。比如日期时间差计算:
select DATE_ADD(my_datetime, INTERVAL 1 DAY)或者是对UNIX时间戳的格式转换:
select UNIX_TIMESTAMP(my_datetime)如果要使用PHP对记录进行查询,则可以很容易地将值的格式更改为UNIX时间戳。
一个重要的区别是,DATETIME表示日期(如在日历中查找),和时间(如在时钟上可以看到),而TIMESTAMP表示明确定义的时间点。
如果应用程序处理时区,那么这可能非常重要。 比如多久以前是‘2019-09-01 16:31:00‘? 这取决于你所在的时区。对我来说,这只是几秒钟前,对你来说,它可能代表将来的时间。
相应地,如果我说自“ 1970-01-01 00:00:00 UTC”以来的1283351460秒,那么您确切地知道我在说什么时间点。
深入学习时间戳 timestamp 在系统失去改变之后,会自动变化。这在程序生产数据时,会有影响。我们通过例子来说明。
首先在系统变量中查看 time_zone 相关配置。
创建新表并写入两个数值。
查看写入的数据。
修改时区,再次查看表内的值。我们发现,timestamp 类型的字段时间随着时区的改变发生了改变。而 datetime 字段则不会改变。
写在最后本文通过对比 timestamp & datetime 字段的优劣和使用场景进行了阐述,并使用例子展示 timestamp 的便捷性,和隐藏的问题。
Happy coding :_)
我是 @程序员小助手 ,持续分享编程知识,欢迎关注。
一、需求描述在业务开发的查询mysql数据库过程中,常常需要查询类似于今天、明天、昨天的数据,或者对日期进行加减计算,比如对某个日期加上几天、几个小时等操作的。在此情况下,我们可以使用date_add...
2024.11.13MySQL存储日期的数据类型有DATE、TIME、YEAR、DATETIME和TIMESTAMP。我们这里主要讨论的是 YYYY-MM-DD HH:MM:SS 格式的时间,因为它用得最多。对于其它格式...
2024.11.15MySQL时间、字符串、戳的转换select date_format(now(), ‘%Y-%m-%d %H:%i:%s’);结果:2018-05-02 20:24:10时间转时间戳select un...
2024.11.07mysql怎么将秒转为时间在mysql中,可以利用FROM_UNIXTIME()函数来将秒转为时间。FROM_UNIXTIME(date) 函数把 UNIX 时间戳(从格林威治时间1970年01月01...
2024.11.131、将日期转换为时间戳:将日期字符串转换为时间戳可以使用UNIX_TIMESTAMP()函数,它可以将日期字符串转换为UNIX时间戳,语法如下:UNIX_TIMESTAMP(date)其中,date表...
2024.11.13