为什么我会得到这个错误?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。
3条答案
按热度按时间nzk0hqpo1#
你得到错误是因为
user_id
列定义为NOT NULL
user_id
列未指定默认值1.也不要在查询中指定它的值
PS:这个问题与
ON DUPLICATE KEY UPDATE
子句无关-如果你不使用它,也会出现同样的错误。PPS:无论是否触发
ON DUPLICATE KEY UPDATE
-您的insert
都应满足所有约束7rfyedvj2#
使用以下命令为
user_id
表设置默认值:ALTER TABLE article ADD user_id int(11) NOT NULL DEFAULT {DEFAULT_VALUE}
或从NOT NULL更改为NULLxzv2uavs3#
如果你知道你只是在更新,但是插入的任何一行都会导致错误,这是一个欺骗。