mysql时间戳用什么类型,MYSQL字段类型时间戳与日期时间应该怎么选?

timestamp, datetime,哪一个是更好的选择?

引言

今天我们把知识的焦点投向数据库方面,因为数据库是应用程序的基石,是一切生产的动力。先说一个小小的知识点,在存储日期时间时,应该选用 timestamp 时间戳类型,还是应该用 datettime 类型?

mysql时间戳用什么类型,MYSQL字段类型时间戳与日期时间应该怎么选?

两者有何不同,效率如何,以及各自的优劣。

学习时间

MySQL中的 timestamp 通常用于跟踪记录的更改,并且通常在每次记录更改时进行更新。如果要存储特定值,则应使用 datetime 字段。

如果你在这两者之间犹豫不决,那就请优先使用时间戳。买搜狗中提供了。内置的函数用于时间,日期格式转换和计算,使用起来非常方便。比如日期时间差计算:

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 在系统失去改变之后,会自动变化。这在程序生产数据时,会有影响。我们通过例子来说明。

mysql时间戳用什么类型,MYSQL字段类型时间戳与日期时间应该怎么选?

首先在系统变量中查看 time_zone 相关配置。

mysql时间戳用什么类型,MYSQL字段类型时间戳与日期时间应该怎么选?

创建新表并写入两个数值。

查看写入的数据。

mysql时间戳用什么类型,MYSQL字段类型时间戳与日期时间应该怎么选?

修改时区,再次查看表内的值。我们发现,timestamp 类型的字段时间随着时区的改变发生了改变。而 datetime 字段则不会改变。

写在最后

本文通过对比 timestamp & datetime 字段的优劣和使用场景进行了阐述,并使用例子展示 timestamp 的便捷性,和隐藏的问题。

Happy coding :_)

我是 @程序员小助手 ,持续分享编程知识,欢迎关注。

mysql时间戳用什么类型,MYSQL字段类型时间戳与日期时间应该怎么选?

ASP如何获取时间戳?

ASP时间戳函数'把标准时间转换为UNIX时间戳

Function ToUnixTime(strTime, intTimeZone) If IsEmpty(strTime) or Not IsDate(strTime) Then strTime = Now If IsEmpty(intTimeZone) or Not isNumeric(intTimeZone) Then intTimeZone = 0 ToUnixTime = DateAdd("h",-intTimeZone,strTime) ToUnixTime = DateDiff("s","1970-01-01 00:00:00", ToUnixTime)End Function'把UNIX时间戳转换为标准时间Function FromUnixTime(intTime, intTimeZone) If IsEmpty(intTime) or Not IsNumeric(intTime) Then FromUnixTime = Now() Exit Function End If If IsEmpty(intTime) or Not IsNumeric(intTimeZone) Then intTimeZone = 0 FromUnixTime = DateAdd("s", intTime, "1970-01-01 00:00:00") FromUnixTime = DateAdd("h", intTimeZone, FromUnixTime)End Function'调用方法:'示例:ToUnixTime("2009-12-05 12:52:25", +8),返回值为1259988745 'response.Write ToUnixTime("2009-12-05 12:52:25", +8)'示例:FromUnixTime("1259988745", +8),返回值2009-12-05 12:52:25 'response.Write FromUnixTime("1259988745", +8)

转载来源网络

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

发表评论

登录后才能评论