大佬教程收集整理的这篇文章主要介绍了golang mysql中timestamp,datetime,int类型的区别与优劣,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
golang time: https://golang.org/pkg/time/
golang中time包用法http://blog.csdn.net/chenbaoke/article/details/41519193
首先 datetiR_878_11845@和timestAMP类型所占的存储空间不同,前者8个字节,后者4个字节,这样造成的后果是两者能表示的时间范围不同。前者范围为1000-01-01 00:00:00 ~ 9999-12-31 23:59:59,后者范围为1970-01-01 08:00:01到2038-01-19 11:14:07。所以可以看到timestAMP支持的范围比DATATIME要小,容易出现超出的情况.
其次,timestAMP类型在默认情况下,insert、update 数据时,timestAMP列会自动以当前时间(CURRENT_TIMESTAMP)填充/更新。
第三,timestAMP比较受时区timezone的影响以及MysqL版本和服务器的sql MODE的影响
所以一般来说,我比较倾向选择datetiR_878_11845@E,至于你说到索引的问题,选择datetiR_878_11845@E作为索引,如果碰到大量数据查询慢的情况,也可以分区表解决。
其实速度上差别不是很大,你可以自己做做测试就知道了。内部存储都是整数,只不过datetiR_878_11845@e和timestamp会仅仅在显示的时候,显示为人能读的日期(当然存储空间有点区别,整形和timestamp都是4字节,datetiR_878_11845@e是8字节),做索引也应该没什么区别,这个不敢确定,如果有请指正我……
另外datetiR_878_11845@e和timestamp相对于int来说也有一个小小的好处,就是对于时间类型来说,可以有一系列的时间函数可以用
Q:MysqL的时间字段貌似有各种选择,像一般的情况(我也是)下就是用INT
型来表示,直接存储时间戳。但是我知道在MysqL里至少还有timestAMP
和datetiR_878_11845@E
型可以用来存储时间,我不知道这三者在使用上各有什么区别,在使用场景上需要怎么考虑,特别是它们在索引或者查询速度上有区别吗?
这几个类型的选择还是看你的需求。
我用timestamp比较多,对于记录日志什么的需求,timestamp绝对够用了,除非你保证说你的程序能一直用到2038年,就算如此也可以用迁移程序处理……
如果需求是允许用户保存一些超过timestamp能保存的时间(@QingchaoWu 已经给出了timestamp的范围)比如说todo list什么的,允许用户计划38年以后的事情,那就用datetiR_878_11845@e好了。
##################################
3. 实际格式储存(Just stores what you have stored and retrieves the same thing which you have stored.)
4. 与时区无关(It has nothing to deal with the TIMEZONE and Conversion.)
5. 不可以设定默认值,所以在不允许为空值的情况下,必须手动指定datetiR_878_11845@e字段的值才可以成功插入数据。4.值以UTC格式保存( it stores the number of milliseconds)
5.时区转化 ,存储时对当前的时区进行转换,检索时再转换回当前的时区。
6. 默认值为CURRENT_TIMESTAMP(),其实也就是当前的系统时间。以上是大佬教程为你收集整理的golang mysql中timestamp,datetime,int类型的区别与优劣全部内容,希望文章能够帮你解决golang mysql中timestamp,datetime,int类型的区别与优劣所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。