Heim  >  Artikel  >  Datenbank  >  Wie konvertiere ich asynchrone MySQL-Operationen in Versprechen in Node.js?

Wie konvertiere ich asynchrone MySQL-Operationen in Versprechen in Node.js?

Susan Sarandon
Susan SarandonOriginal
2024-10-25 17:28:02828Durchsuche

How to Convert Asynchronous MySQL Operations to Promises in Node.js?

Asynchrone MySQL-Operationen in Versprechen in Node.js konvertieren

Die asynchrone Natur von Node.js stellt eine Herausforderung für Entwickler dar, die von Python kommen. Um dieses Problem zu beheben, versucht dieser Codeausschnitt, einen MySQL-Vorgang in eine asynchrone Funktion einzubinden, die einen Wert zurückgibt. Dieser Ansatz funktioniert jedoch aufgrund der asynchronen Natur von Node.js nicht.

Um dieses Problem zu beheben, muss der Vorgang umgestaltet werden, um ein Versprechen zurückzugeben. Mit Bluebird kann dies wie folgt erreicht werden:

<code class="javascript">function getLastRecord(name) {
  return new Promise((resolve, reject) => {
    // Establish a connection to MySQL
    const connection = getMySQL_connection();

    // Construct and execute the MySQL query
    const query_str = `SELECT name, FROM records WHERE (name = ?) LIMIT 1`;
    const query_var = [name];
    connection.query(query_str, query_var, (err, rows, fields) => {
      if (err) {
        return reject(err);
      }
      resolve(rows);
    });
  });
}</code>

Jetzt können Sie die zurückgegebenen Zeilen wie gewünscht verarbeiten:

<code class="javascript">getLastRecord('name_record').then((rows) => {
  // Access the rows and perform operations

  if (rows.length > 20) {
    console.log("action");
  }
}).catch((err) => {
  // Handle any errors
  setImmediate(() => { throw err; });
});</code>

Dieser Ansatz stellt sicher, dass die Operation asynchron ausgeführt wird, während So können Sie den zurückgegebenen Wert mithilfe von Versprechen synchron verarbeiten.

Das obige ist der detaillierte Inhalt vonWie konvertiere ich asynchrone MySQL-Operationen in Versprechen in Node.js?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn