V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
xiaoyanbot
V2EX  ›  MySQL

为什么 mysql 的 timestamp 字段允许录入 0000-00-00 00:00:00

  •  
  •   xiaoyanbot · 2018-08-24 14:08:06 +08:00 · 3762 次点击
    这是一个创建于 2282 天前的主题,其中的信息可能已经有所发展或是发生改变。

    8 条回复    2018-09-08 15:09:48 +08:00
    tedzhou1221
        1
    tedzhou1221  
       2018-08-24 14:10:15 +08:00
    好像可以设置,5.7 版本以上的好像是默认禁止
    liprais
        2
    liprais  
       2018-08-24 14:42:08 +08:00
    mysql 智障呗
    zengzizhao
        3
    zengzizhao  
       2018-08-24 15:01:54 +08:00
    5.7 之前是可以
    这有什么奇怪的
    owenliang
        4
    owenliang  
       2018-08-24 17:29:54 +08:00
    的确是智障,我这两天 mysql 数据同步 ES,因为这个问题挂逼了。
    janxin
        5
    janxin  
       2018-08-25 09:40:08 +08:00 via iPad
    mysql 智障的问题多了…
    xiaoyanbot
        6
    xiaoyanbot  
    OP
       2018-08-26 11:47:33 +08:00
    @tedzhou1221 看了,5.7 也可以 0 插入
    ERRORatDAY1
        7
    ERRORatDAY1  
       2018-09-08 15:00:18 +08:00
    set global explicit_defaults_for_timestamp=on;
    ERRORatDAY1
        8
    ERRORatDAY1  
       2018-09-08 15:09:48 +08:00
    @ERRORatDAY1 set global sql_mode='............................,NO_ZERO_DATE';
    断开连接,重新进入。或者以上两条变量设置的时候就是 session 级别;
    create table t1(shijian timestamp);
    insert into table t1 values(0);
    ERROR 1292 (22007): Incorrect datetime value: '0' for column 'id' at row 1
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2806 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 11:51 · PVG 19:51 · LAX 03:51 · JFK 06:51
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.