zoukankan      html  css  js  c++  java
  • mysql timestamp

     一般建表时候,创建时间用datetime,更新时间用timestamp。这是非常重要的。

    【1】timestamp字段所在行更新时,timestamp字段会被更新成当前时间

    (1.1)一个表中出现了两个timestamp字段类型

    我测试了一下,如果你的表中有两个timestamp字段,只要你更新任何非timestamp字段的值,则第一个timestamp列会更新成当前时间,而第二人timestamp列的值不变。

    如图中我的操作,即使我没有设置request_time属性为ON UPDATE CURRENT_TIMESTAMP,也会自动更新,你就说坑不坑!!!

      

     (1.2)使用查找原因

    show create table [表名]

    查看了一下MySQL系统create创建默认语句,果然发现问题!!创建request_time时MySQL会默认自动给第一个timestamp字段加上DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP。

    想去掉“自动更新:ON UPDATE CURRENT_TIMESTAMP”

    只写DEFAULT CURRENT_TIMESTAMP,则会把mysql系统默认的“自动更新:ON UPDATE CURRENT_TIMESTAMP”去掉。

    只写NULL 则会把mysql系统默认的“DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP”全部去掉。

    而第二个timestamp字段不会。(第二个不会是因为第二个写了 null !)

      

    (1.3)解决方法:实用例子(使用timestamp最佳方案)

    ① 创建 timestamp NULL DEFAULT NULL:

      

    ② 测试一下各种场景:

     

    完美解决!!!!!!

     ———————————————————————

    (1.4)总结:

    总结测试 5.7

    创建形式 实际形式

    request1 TIMESTAMP NOT NULL default current_timestamp

    `request1` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP
    request2 TIMESTAMP null `request2` timestamp NULL DEFAULT NULL
    request3 TIMESTAMP not null

    `request3` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00'

    如果放在其他 timestamp列之前,或只有它自己一个timestamp,则会变成如下:

    `request3` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP

    request4 TIMESTAMP default 0 `request4` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00'

    (1)当 request3 TIMESTAMP not null 列在timestamp字段中不是第一个字段时时

      

     (2)当 request3 TIMESTAMP not null 字段是第一个timestamp 字段是

      

    二、MySQL日期类型DATETIME和TIMESTAMP 相关问题详解

    MySQL的日期类型有三种:DATETIME、DATE和TIMESTAMP,除了DATE用来表示一个不带时分秒的是日期,另外两个都带时分秒。TIMESTAMP还可以精确到毫秒。

    其次还有个共性,就是他们的格式“不严格”,很自由,一般你认为对的格式都可以正确插入到数据库中。

    这里主要解决带时分秒日期的一些常见问题。

    (2.1)TIMESTAMP

    1、TIMESTAMP列MySQL系统默认为NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP;

      默认值可以为“0000-00-00 00:00:00”(前提是mysql的sql_model是非严格模式),但默认不能为null(如果想为null,则需要:[字段名] timestamp NULL DEFAULT NULL,也可以只写 [字段名] timestamp NULL(系统会给默认增加DEFAULT NULL,不信可以使用show create table [表名]查看))。
    2、如果ON UPDATE CURRENT_TIMESTAMP时(注意是系统默认加上的)TIMESTAMP列不可以设置值,只能由数据库自动去修改。(原文的这个说法不对,timestamp可以修改,只不过即使改完,也会被ON UPDATE CURRENT_TIMESTAMP覆盖掉)

    3、一个表可以存在多个TIMESTAMP列,但只有一个列会根据数据更新而改变为数据库系统当前值。因此,一个表中有多个TIMESTAMP 列是没有意义,实际上一个表只设定一个TIMESTAMP列。

    4、TIMESTAMP列的默认值是CURRENT_TIMESTAMP常量值。当纪录数据发生变化的时候,TIMESTAMP列会自动将其值设定为CURRENT_TIMESTAMP(坑在这:自动更新)。

    5、TIMESTAMP列创建后的格式是:

      `a` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,

      这个语句含义,a字段的默认值是CURRENT_TIMESTAMP,当纪录更新时候,自动将a字段的值设置为 CURRENT_TIMESTAMP。
    6、另外,下面的定义从语法角度是对的,但是没有意义,因为该字段的值不可更改,永远只能为默认值。
    `b` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
    (原文的这个说法不对,timestamp可以修改,DEFAULT内容也可以是任意格式的timestamp,不用非必需为CURRENT_TIMESTAMP)

    (2.2)DATETIME

    1、DATETIME列可以设置为多个,默认可为null,可以手动设置其值。

    2、DATETIME列不可设定默认值,这是很多人煞费苦心研究的成果,呵呵!(其实是可以的 8.0亲测,5.7也可以)

    3、DATETIME列可以变相的设定默认值,比如通过触发器、或者在插入数据时候,将DATETIME字段值设置为now(),这样可以做到了,尤其是后者,在程序开发中常常用到。

    一般建表时候,创建时间用datetime,更新时间用timestamp。

    CREATE TABLE user (
    id bigint(20) NOT NULL AUTO_INCREMENT,
    name varchar(20) CHARACTER SET gbk NOT NULL,
    sex tinyint(1) DEFAULT1′,
    state smallint(2) DEFAULT1′,
    createtime datetime NOT NULL,
    updatetime timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
    PRIMARY KEY (id)
    ) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=latin1

    (2.3)日期最大值范围的问题

    日期最大范围的问题不是绝对的,很多人制定一个说不能查过20XX年,这是扯蛋,根本没这回事。日期的范围等问题与MySQL的运行模式有关。

    当然这个范围很宽广,足够祖宗十八代用了,不用担心这问题了。

    相反,要注意的问题是,编程语言对日期范围的限制,不同的语言,有不同的限制,这里不做讨论了。

    (2.4)日期格式转换

    1、字符串转日期

    select STR_TO_DATE(‘2010-03-03 16:41:16′, ‘%Y-%m-%d %H:%i:%s’)

    2、日期转字符串

    select DATE_FORMAT(‘2010-03-03 16:41:16′, ‘%Y-%m-%d %H:%i:%s’)

    (2.5)日期的中 年月日时分秒星期月份 等获取方法

    select TIMESTAMP(‘2010-03-03 16:41:16′);

    select DATE(‘2010-03-03 16:41:16′);

    select YEAR(‘2010-03-03 16:41:16′);

    select MONTH(‘2010-03-03 16:41:16′);

    select DAY(‘2010-03-03 16:41:16′);

    select TIME(‘2010-03-03 16:41:16′);

    select CURTIME();

    select CURDATE();

    select CURRENT_DATE;

    select CURRENT_TIME;

    select CURRENT_TIMESTAMP;

    方式很多,这里简单列举一二。

    (2.6)日期的算术运算

    相关的函数很多很多,用法也很简单,一看就会,建议查看MySQL参考手册。

    mysql> SELECT DATE_ADD(‘1999-01-01′, INTERVAL 1 DAY);

    -> ‘1999-01-02′

    mysql> SELECT DATE_ADD(‘1999-01-01′, INTERVAL 1 HOUR);

    -> ‘1999-01-01 01:00:00′

    mysql> SELECT DATE_ADD(‘1998-01-30′, INTERVAL 1 MONTH);

    -> ‘1998-02-28′

    (2.7)日期的大小比较

    拿着日当数字,拿着字符串当日期,呵呵,很简单的。

    and update_time > ‘2010-03-02 16:48:41′
    and update_time <= ‘2010-03-03 16:51:58′

  • 相关阅读:
    1012 The Best Rank (25 分)(排序)
    1011. World Cup Betting (20)(查找元素)
    1009 Product of Polynomials (25 分)(模拟)
    1008 Elevator (20 分)(数学问题)
    1006 Sign In and Sign Out (25 分)(查找元素)
    1005 Spell It Right (20 分)(字符串处理)
    Kafka Connect 出现ERROR Failed to flush WorkerSourceTask{id=local-file-source-0}, timed out while wait
    flume、kafka、avro组成的消息系统
    Java23种设计模式总结【转载】
    Java编程 思维导图
  • 原文地址:https://www.cnblogs.com/gered/p/15402289.html
Copyright © 2011-2022 走看看