【记录】mysql中建表utf8和utf8mb4区别?timestamp和datetime区别?
mysql中建表utf8和utf8mb4区别?
1:utf8 是 Mysql 中的一种字符集,只支持最长三个字节的 UTF-8字符,也就是 Unicode 中的基本多文本平面
2:要在 Mysql 中保存 4 字节长度的 UTF-8 字符,需要使用 utf8mb4 字符集,但只有 5.5.3
3:版本以后的才支持(查看版本: select version();)。我觉得,为了获取更好的兼容性,应该总是使用 utf8mb4 而非 utf8.
4:对于 CHAR 类型数据,utf8mb4 会多消耗一些空间,根据 Mysql 官方建议,使用 VARCHAR 替代 CHAR。
为了获取更好的兼容性,应该总是使用 utf8mb4 而非 utf8,事实上,最新版的phpmyadmin默认字符集就是utf8mb4。诚然,对于 CHAR 类型数据,使用utf8mb4 存储会多消耗一些空间。
那么utf8mb4比utf8多了什么的呢?
多了emoji编码支持.
如果实际用途上来看,可以给要用到emoji的库或者说表,设置utf8mb4.
比如评论要支持emoji可以用到.
建议普通表使用utf8 如果这个表需要支持emoji就使用utf8mb4
timestamp和datetime区别?
1 区别
1.1 占用空间
类型 | 占据字节 | 表示形式 |
---|---|---|
datetime | 8 字节 | yyyy-mm-dd hh:mm:ss |
timestamp | 4 字节 | yyyy-mm-dd hh:mm:ss |
1.2 表示范围
类型 | 表示范围 |
---|---|
datetime | '1000-01-01 00:00:00.000000' to '9999-12-31 23:59:59.999999' |
timestamp | '1970-01-01 00:00:01.000000' to '2038-01-19 03:14:07.999999' |
timestamp
翻译为汉语即"时间戳",它是当前时间到 Unix元年(1970 年 1 月 1 日 0 时 0 分 0 秒)的秒数。对于某些时间的计算,如果是以 datetime
的形式会比较困难,假如我是 1994-1-20 06:06:06
出生,现在的时间是 2016-10-1 20:04:50
,那么要计算我活了多少秒钟用 datetime
还需要函数进行转换,但是 timestamp
直接相减就行。
1.3 时区
timestamp
只占 4 个字节,而且是以utc
的格式储存, 它会自动检索当前时区并进行转换。
datetime
以 8 个字节储存,不会进行时区的检索.
也就是说,对于timestamp
来说,如果储存时的时区和检索时的时区不一样,那么拿出来的数据也不一样。对于datetime
来说,存什么拿到的就是什么。
还有一个区别就是如果存进去的是NULL
,timestamp
会自动储存当前时间,而 datetime
会储存 NULL
。
参考链接:https://segmentfault.com/a/1190000017393602?utm_source=tag-newest
建表时候设置created_time和updated_time自动设置时间报错?
Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause
在MySQL 5.6.5版本之前,Automatic Initialization and Updating只适用于TIMESTAMP,而且一张表中,最多允许一个TIMESTAMP字段采用该特性。
从MySQL 5.6.5开始,Automatic Initialization and Updating同时适用于TIMESTAMP和DATETIME,且不限制数量。
所以建表时候可以这么写
`created_by` varchar(20) DEFAULT NULL COMMENT '创建用户',
`created_time` timestamp DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updated_by` varchar(20) DEFAULT NULL COMMENT '更新用户',
`updated_time` timestamp DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
希望能帮助到需要的人。
最新文章
- JAVA CDI 学习(3) - @Produces及@Disposes
- npm报错Error: ENOENT, stat 'D:\NodeLearn\node-global'
- TCPdump抓包命令详解--摘
- centos7 安装mariaDB 以及 phpmyadmin的安装
- php过滤参数特殊字符防注入
- 读懂Swift 2.0中字符串设计思路的改变
- 百度GPSutil
- [自制操作系统] 图形界面&VBE工具&MMIO显存&图形库/字库
- Nginx学习——Nginx启动、停止、重启和信号控制以及平滑升级
- c#动态编译并执行字符串
- 【XML】 XML格式一些记录
- Java并发框架——AQS之如何使用AQS构建同步器
- 无限极分类(adjacency list)的三种方式(迭代、递归、引用)
- js原生实现div渐入渐出
- Mac Office 2016 破解
- AndroidStudio Terminal的使用
- MapReduce 踩坑 :Aggregation is not enabled. Try the nodemanager at IP:HOST
- IOS - 修改APP桌面名称为中文名称!
- 关于WSSE验证-- 一种验证用户的方法
- PreparedStatement批量处理和事务