집 >데이터 베이스 >MySQL 튜토리얼 >Node.js에서 MySQL을 쿼리할 때 Async/Await가 동시성 문제를 어떻게 해결할 수 있나요?
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(); } })();
이 수정된 코드에서는:
이 접근 방식을 사용하면 쿼리를 원활하게 동기화하고 안정적인 방식으로 원하는 출력을 얻을 수 있으므로 async/await를 Node.js에서 비동기 작업 처리
위 내용은 Node.js에서 MySQL을 쿼리할 때 Async/Await가 동시성 문제를 어떻게 해결할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!