• 【记录】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来说,存什么拿到的就是什么。

    还有一个区别就是如果存进去的是NULLtimestamp会自动储存当前时间,而 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 
    

      

    希望能帮助到需要的人。

  • 相关阅读:
    yii中通过HTTP post接收
    网络编程
    python 异常处理
    面向对象(2)
    面向对象
    什么是模块精讲
    常用模块二
    各种推导式详解
    匿名函数
    迭代器生成器
  • 原文地址:https://www.cnblogs.com/wbl001/p/11726858.html
Copyright © 2020-2023  润新知