节点Mysql On Duplicate Key Update仅更新唯一行

我正在使用MySQL 5.7和Node JS 6.11.0,并且每当我插入冲突行时我都会尝试更新UNIQUE MysqL列.但是,当我尝试插入冲突记录时,只有现有记录更新为NULL并且不会发生插入.这是我的代码

     pool.getConnection(function(err,connection) {
        var newClass = req.body;
        var query = `INSERT INTO classes SET ? ON DUPLICATE KEY UPDATE teacher_id = NULL`;

        connection.query(query,newClass,function(err,result) {   
            console.log(result);
            if(result.affectedRows >= 1) {
                res.status(201).end();
                res.json(result);
            }
        });
        connection.release();
    });`

我必须为要插入的行运行两次查询;第一次将冲突列设置为null,然后当我再次运行相同的查询时,将插入该行,因为没有冲突.

我已经生成sql并从MysqL控制台直接运行它,我仍然需要为要插入的新行运行两次查询.我不明白为什么这样做.

sql statement is

INSERT INTO classes SET `stream` = 'Red',`form` = '1',`teacher_id` = '7' ON DUPLICATE KEY UPDATE teacher_id = NULL

我的创建表sql

| classes | CREATE TABLE `classes` (
      `id` int(11) NOT NULL AUTO_INCREMENT,`form` varchar(10) NOT NULL,`stream` varchar(15) NOT NULL,`teacher_id` int(11) DEFAULT NULL,PRIMARY KEY (`id`),UNIQUE KEY `teacher_id` (`teacher_id`),CONSTRAINT `classes_ibfk_1` FOREIGN KEY (`teacher_id`) REFERENCES `teachers` 
      ( `id` ) 
   ) ENGINE=InnoDB AUTO_INCREMENT=33 DEFAULT CHARSET=latin1 |`

为什么MysqL表现如此?

最佳答案
INSERT INTO classes
        SET stream = 'Red',form = '1',teacher_id = '7'
    ON DUPLICATE KEY UPDATE teacher_id = NULL;

在存在冲突记录(重复的唯一键或主键)时告诉MysqL,将违规行的teacher_id列设置为null并停止.

您有几种方法可以达到理想的效果.

首先,您可以使用REPLACE语法.

REPLACE INTO classes SET stream = 'Red',teacher_id = '7';

这将首先删除具有UNIQUE或主键约束的违规行,并插入具有指定值的新行.缺点是任何省略的列值都将丢失并设置为其认值.如果未在查询中指定,还将创建新的自动生成(如果有)id.
如果没有违规记录,则会发生正常的INSERT.

否则,您可以在UPDATE子句中使用VALUES.

INSERT INTO classes
        SET stream = 'Red',teacher_id = '7'
    ON DUPLICATE KEY UPDATE stream = VALUES(stream),form   = VALUES(form);

相反,它会将违规行的记录更新为查询的INSERT部分中指定的值.

参考文献:

> https://dev.mysql.com/doc/refman/5.7/en/replace.html
> https://dev.mysql.com/doc/refman/5.7/en/insert-on-duplicate.html

根据新意图更新

为了在离开前一行时创建新记录,在使用INSERT之前,您需要首先使现有行上的UNIQUE约束无效.
目前在单个查询中没有方法可以使用MysqL.

由于INSERT的限制,完成所需操作的最简单方法是在INSERT查询之前运行UPDATE查询.

UPDATE classes 
   SET teacher_id = NULL
   WHERE teacher_id = '7';
INSERT INTO classes
   SET stream = 'Red',teacher_id = '7';

这将首先检查冲突的teacher_id记录并将其设置为null.如果不存在冲突记录,则不会进行更新.然后,以下INSERT将创建所需的记录,而不会发生冲突.

相关文章

优化MySQL数据库发布系统存储的方法有:1.mysql库主从读写分...
使用mysql的方法:在“我的电脑”→右键→“管理”→“服务”...
在mysql中查看root用户权限的方法:1.命令行启动mysql服务;...
MySQL主从复制是用来备份一个与主数据库一样环境的从数据库,...
运行mysql的方法1.启动mysql服务,在“我的电脑”→右键→“...
开启mysql的方法1.可以通过快捷键win+r,输入cmd,打开窗口,...