"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Promise를 사용하여 Node.js에서 MySQL 반환 값을 비동기적으로 처리하는 방법은 무엇입니까?

Promise를 사용하여 Node.js에서 MySQL 반환 값을 비동기적으로 처리하는 방법은 무엇입니까?

2024-11-08에 게시됨
검색:636

How to Handle MySQL Return Values Asynchronously in Node.js with Promises?

Node.js에서 MySQL 반환 값 처리를 위한 Promise 활용

Python에서 Node.js로 전환할 때 Node.js의 비동기적 특성은 다음과 같습니다. Node.js는 도전 과제를 제시할 수 있습니다. getLastRecord(name).

와 같은 MySQL 함수에서 값을 반환해야 하는 시나리오를 생각해 보세요. 전통적으로 Node.js는 비동기 작업에 콜백을 사용합니다. 그러나 getLastRecord()의 비동기 특성을 처리하기 위해 Promises를 활용합니다.

Promise를 사용하여 함수를 구현하려면:

function getLastRecord(name) {
  return new Promise((resolve, reject) => {
    // Setup MySQL connection and query
    // ...

    connection.query(query_str, query_var, (err, rows, fields) => {
      if (err) {
        return reject(err); // Handle error
      }
      resolve(rows); // Resolve with results
    }); // Callback function
  });
}

반환된 값을 처리하려면 .then() 및 .catch() 콜백을 Promise:

getLastRecord('name_record')
  .then((rows) => {
    // Handle returned rows here
    console.log(rows);
  })
  .catch((err) => {
    // Handle errors here
    console.log(err);
  });

조건부 검사를 구현할 수도 있습니다:

getLastRecord('name_record')
  .then((rows) => {
    if (rows.length > 20) {
      console.log('action');
    }
  });

이 시나리오에서 Promise를 채택하면 비동기 작업을 처리하는 데 더 구조화되고 읽기 쉬운 접근 방식을 도입하여 더 깔끔하고 유지 관리하기 쉬운 코드베이스를 보장할 수 있습니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3