两者有何不同,效率如何,以及各自的利害。
学习韶光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 :_)
我是 @程序员小助手 ,持续分享编程知识,欢迎关注。