>데이터 베이스 >MySQL 튜토리얼 >단일 노드-MySQL 쿼리에서 여러 SQL 문을 어떻게 실행할 수 있나요?

단일 노드-MySQL 쿼리에서 여러 SQL 문을 어떻게 실행할 수 있나요?

Susan Sarandon
Susan Sarandon원래의
2024-12-20 09:32:11640검색

How Can I Execute Multiple SQL Statements in a Single Node-MySQL Query?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.