집 >데이터 베이스 >MySQL 튜토리얼 >단일 노드-MySQL 쿼리에서 여러 SQL 문을 어떻게 실행할 수 있나요?
node-mysql을 사용하여 단일 쿼리에서 여러 SQL 문 실행
node-mysql을 사용하여 단일 쿼리에서 여러 DELETE 문을 실행할 때 오류가 발생한다고 언급하셨습니다. 노드-mysql. 이 문제를 해결하려면 연결 구성에서 여러 문에 대한 지원을 활성화해야 합니다.
다중 문 쿼리 활성화
node-mysql 문서에서는 여러 문 지원에 대해 설명합니다. 보안상의 이유로 처음에는 비활성화되어 SQL 주입 공격을 방지합니다. 이를 활성화하려면 연결 구성에 다음 줄을 추가하세요.
var connection = mysql.createConnection({multipleStatements: true});
다중 문 실행
여러 문이 활성화되면 여러 문을 사용하여 쿼리를 실행할 수 있습니다. 각 명령문을 세미콜론(;)으로 구분하여 명령문을 작성합니다. 결과는 각 문에 대한 배열을 포함하는 배열이 됩니다.
예
다음 코드를 고려하세요.
connection.query('DELETE FROM user_tables WHERE name = 'Testbase';DELETE FROM user_tables_structure WHERE parent_table_name = 'Testbase';DELETE FROM user_tables_rules WHERE parent_table_name = 'Testbase';DELETE FROM user_tables_columns WHERE parent_table_name = 'Testbase';', [1, 2], function(err, results) { if (err) throw err; // `results` is an array with one element for every statement in the query: console.log(results[0]); // [{1: 1}] console.log(results[1]); // [{2: 2}] });
여러 문을 활성화하여 세미콜론으로 문을 적절하게 구분하면 단일 쿼리에서 모든 DELETE 작업을 실행할 수 있습니다.
위 내용은 단일 노드-MySQL 쿼리에서 여러 SQL 문을 어떻게 실행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!