网站首页 > 博客文章 正文
引言
今天我们把知识的焦点投向数据库方面,因为数据库是应用程序的基石,是一切生产的动力。先说一个小小的知识点,在存储日期时间时,应该选用 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 :_)
我是 @程序员小助手 ,持续分享编程知识,欢迎关注。
猜你喜欢
- 2024-12-06 超详细canal入门,看这篇就够了
- 2024-12-06 MySQL专题1: 字段和索引
- 2024-12-06 这些MySQL面试题集锦,据说知名互联网公司都用
- 2024-12-06 mysql数据库一天五万条以上的增量,预计运维三年,怎么优化
- 2024-12-06 Mysql时间格式转化——DATE_FORMAT()
- 2024-12-06 RPA数据库功能应用及时间戳获取
- 2024-12-06 Mysql日期函数、时间函数的实际应用
- 2024-12-06 MySQL时间、字符串、戳的转换
- 2024-12-06 MySQL系列-第2篇:MySQL中数据类型介绍
- 2024-12-06 Mysql:TIMESTAMP、DATETIME、BIGINT。该如何选择?
你 发表评论:
欢迎- 最近发表
-
- 比GoPro 13更强的大疆Action 5 Pro,到底强在哪里?
- 信号和槽(信号和槽的实现原理)
- 在响应式项目中连接设计与开发(请简述实现响应式设计包括哪些技术点)
- 【C#】委托、Action、Func 和 Event 之间的关系
- 如何使用JavaScript实现Prompt弹窗?
- 谷歌Magic Actions功能曝光:AI革新安卓16通知交互
- 基于目标TPS的性能测试,如何通过手动设置场景进行测试?
- IOS基础学习之输出口和动作(io口输入输出实验总结及体会)
- 《Java语言程序设计》期末考试模拟试题——判断题和问答题
- Android学习之Touch事件的处理(android触摸事件实例)
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)