В зависимости от того, насколько сложна ваша транзакция, вы можете столкнуться с некрасивым вложением, пытаясь поставить в очередь свои запросы из Node, что может привести к появлению проблемных областей видимости переменных.
Вместо этого вы можете написать хранимую процедуру и завершить ее SELECT
флагом успеха / неудачи, а затем запросить процедуру с помощью node-mysql , как если бы вы запросили SELECT
. Вот как может выглядеть хранимая процедура:
DELIMITER //
DROP PROCEDURE IF EXISTS MyProcedure //
CREATE PROCEDURE MyProcedure(IN param1 VARCHAR/*, My, Parameters, ... */)
BEGIN
DECLARE EXIT HANDLER FOR NOT FOUND, SQLWARNING, SQLEXCEPTION
BEGIN
ROLLBACK;
SELECT 0 AS res;
END;
START TRANSACTION;
# My Transaction ...
COMMIT;
SELECT 1 AS res;
END //
DELIMITER ;
Ваш код узла будет выглядеть примерно так:
var mysql = require('mysql');
var client = mysql.createClient({
host : '127.0.0.1',
user : 'username',
password: 'password'
});
client.query('USE mydatabase');
var myParams = "'param1', 'param2', ... ";
client.query("CALL MyProcedure(" + myParams + ")", function(err, results, fields) {
if (err || results[0].res === 0) {
throw new Error("My Error ... ");
} else {
// My Callback Stuff ...
}
});