微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么更新/删除成功时受影响的行返回0?

我有声明:

INSERT INTO infotbl(name, phone) VALUES('Alex', '9999999');

并更新它:

UPDATE infotbl SET name = 'Alex Johnes', phone = '999 34356063' WHERE id = 1;

然后删除

DELETE FROM infotbl WHERE id = 1;

当我在MysqL中更新和删除行时,我已成功插入.但是我在Node中的代码返回受影响的行=0.为什么?.我的功能是在Node中更新和删除

function deleteCustomer (id, callback) {
        db.connection.query("DELETE FROM infotbl WHERE id=?", id, (err, result) => {
            if (err) throw err;
            if (result.affectedRows > 0)
                callback(true);
            else
                callback(false);
        });
    };

和更新功能

function updateCustomer(id, name, phone, callback) {
    db.connection.query("UPDATE infotbl SET name = ?, phone = ? WHERE id = ?;", [name, phone, id], (err, result) => {
        if (err) throw err;
                if (result.affectedRows > 0)
                    callback(true);
                else
                    callback(false);
});
}

数据库成功执行后,为什么节点返回0个受影响的行?

解决方法:

最可能的解释是,没有满足UPDATE和DELETE语句中条件的行.也就是说,没有id等于1的行.

如果条件匹配一个或多个行,则UPDATE可能会影响零行,但是应用于该行的更改将导致“无更改”……也就是说,被修改的列已经分配了值.

成功执行但影响零行的UPDATE或DELETE仍被视为成功.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐