>데이터 베이스 >MySQL 튜토리얼 >Node.js에서 MySQL을 쿼리할 때 Async/Await가 동시성 문제를 어떻게 해결할 수 있나요?

Node.js에서 MySQL을 쿼리할 때 Async/Await가 동시성 문제를 어떻게 해결할 수 있나요?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-29 01:41:12634검색

How Can Async/Await Solve Concurrency Issues When Querying MySQL in Node.js?

Node.js의 비동기 실행: MySQL에서 Async/Await 사용

Node.js를 처음 사용하는 경우 적응하는 데 어려움을 겪을 수 있습니다. 특히 비동기 작업을 수행할 때 최신 구문을 사용합니다. MySQL 데이터베이스를 쿼리할 때 async/await 키워드를 사용하여 동기화된 결과를 얻는 방법을 살펴보겠습니다.

코드에서 여러 쿼리를 실행하고 결과를 단일 문자열로 연결하려고 합니다. 그러나 Node.js는 비차단 방식으로 JavaScript 코드를 실행하므로 아래 코드는 string1 ~ string4 변수에 예상 결과가 포함된다는 것을 보장하지 않습니다.

// Original Code
var string1 = '';
var string2 = '';
var string3 = '';
var string4 = '';

DatabasePool.getConnection((err, connection) => {
  // Query 1
  connection.query(query, (err, result) => {
    string1 = result;
  });

  // Query 2
  connection.query(query, (err, result) => {
    string2 = result;
  });

  // Query 3
  connection.query(query, (err, result) => {
    string3 = result;
  });

  // Query 4
  connection.query(query, (err, result) => {
    string4 = result;
  });

  // Attempt to concatenate results
  var appended_text = string1 + string2 + string3 + string4;
});

Solution with Async/ 기다리세요

이 문제를 해결하고 동기 실행을 허용하기 위해 Node.js 8은 util.promisify()를 제공합니다. 기능. MySQL 라이브러리와 통합하는 방법은 다음과 같습니다.

// Improved Code
const mysql = require('mysql');
const util = require('util');
const conn = mysql.createConnection({ yourHOST, yourUSER, yourPW, yourDB });

// Promisify the query method
const query = util.promisify(conn.query).bind(conn);

(async () => {
  try {
    // Execute queries concurrently
    const [query1Result, query2Result, query3Result, query4Result] = await Promise.all([
      query('select count(*) as count from file_managed'),
      query('another query'),
      query('another query'),
      query('another query'),
    ]);

    // Concatenate results
    const appended_text = query1Result[0].count + query2Result[0].count + query3Result[0].count + query4Result[0].count;
  } finally {
    // Close the connection
    conn.end();
  }
})();

이 수정된 코드에서는:

  • 쿼리 메서드는 util.promisify()를 사용하여 Promise로 변환됩니다.
  • bind() 함수는 이것이 여전히 원래 객체를 참조하도록 보장합니다.
  • Promise.all() 메소드는 4개의 쿼리를 동시에 실행하고 결과 배열을 반환합니다.
  • 결과가 추출되어appended_text로 연결됩니다.
  • 마지막으로 연결이 닫힙니다.

이 접근 방식을 사용하면 쿼리를 원활하게 동기화하고 안정적인 방식으로 원하는 출력을 얻을 수 있으므로 async/await를 Node.js에서 비동기 작업 처리

위 내용은 Node.js에서 MySQL을 쿼리할 때 Async/Await가 동시성 문제를 어떻게 해결할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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