ON DUPLICATE KEY UPDATE的MySQL默认值错误

时间:2013-07-05 00:43:33

标签: mysql

为什么我收到此错误? MySQL版本有什么变化会导致这个(在某一点上工作)现在失败了吗?如果插入已完成,INSERT INTO不指定 所需的user_id值,但由于id 1已存在,因此应该成为UPDATE且有效。

mysql> select * from article;
+----+---------+---------------------+-----------+-----------+
| id | user_id | published_at        | title     | content   |
+----+---------+---------------------+-----------+-----------+
|  1 |       1 | 2011-12-10 12:10:00 | article 1 | content 1 |
|  2 |       2 | 2011-12-20 16:20:00 | article 2 | content 2 |
|  3 |       1 | 2012-01-04 22:00:00 | article 3 | content 3 |
+----+---------+---------------------+-----------+-----------+
3 rows in set (0.00 sec)

mysql> desc article;
+--------------+------------------+------+-----+-------------------+----------------+
| Field        | Type             | Null | Key | Default           | Extra          |
+--------------+------------------+------+-----+-------------------+----------------+
| id           | int(11) unsigned | NO   | PRI | NULL              | auto_increment |
| user_id      | int(11) unsigned | NO   | MUL | NULL              |                |
| published_at | datetime         | NO   |     | CURRENT_TIMESTAMP |                |
| title        | varchar(100)     | NO   |     | NULL              |                |
| content      | text             | NO   |     | NULL              |                |
+--------------+------------------+------+-----+-------------------+----------------+
5 rows in set (0.01 sec)

mysql> INSERT INTO article (id)
    -> VALUES (1)
    -> ON DUPLICATE KEY UPDATE title = 'article 1b', content = 'content 1b';
ERROR 1364 (HY000): Field 'user_id' doesn't have a default value

MySQL版本5.6.12。

2 个答案:

答案 0 :(得分:6)

您收到错误是因为

  1. user_id列定义为NOT NULL
  2. user_id列没有指定默认值
  3. 您不在查询中指定其值
  4. PS:这个问题与ON DUPLICATE KEY UPDATE子句无关 - 如果你没有使用它也会出现同样的错误。

    PPS:无论ON DUPLICATE KEY UPDATE是否已触发 - 您的insert应满足所有约束

答案 1 :(得分:0)

使用user_idALTER TABLE article ADD user_id int(11) NOT NULL DEFAULT {DEFAULT_VALUE}表设置默认值 或从NOT NULL更改为NULL