我想在 node-mysql 中执行事务(通过执行查询 START TRANSACTION、ROLLBACK、COMMIT)。我有这段代码:
conn.query("START TRANSACTION");
conn.query("INSERT INTO users (id, name, age) VALUES (1, 'Mat', '24')", function(e){
if (e){
conn.query("ROLLBACK", callback);
}
else{
conn.query("COMMIT", callback);
}
});
conn.query("INSERT INTO users (name, age) VALUES ('Mat', '24')", function(e, r){
console.log(e); // null
console.log(r); // {fieldCount: 0, affectedRows: 1, insertId: 2, serverStatus: 3, warningCount: 0, message: ''}
});
为了测试回滚情况,我故意将 id 设置为 1,这会导致索引重复错误。事务被回滚,但问题是事务之外的第二个插入没有执行。没有记录错误,而且 - 对我来说很奇怪 - 当我在第二次插入之后选择整个表时,结果中有新行。但在另一个连接中它消失了。所以看起来在连接结束时新创建的行被删除了。提交事务时不会出现问题。