Heim > Datenbank > MySQL-Tutorial > Hauptteil

Wie behandelt man MySQL-Rückgabewerte asynchron in Node.js mit Versprechen?

Barbara Streisand
Freigeben: 2024-10-26 16:33:02
Original
180 Leute haben es durchsucht

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

Nutzung von Versprechen zur Verarbeitung von MySQL-Rückgabewerten in Node.js

Beim Übergang von Python zu Node.js ist die asynchrone Natur von Node. js kann Herausforderungen mit sich bringen. Stellen Sie sich ein Szenario vor, in dem Sie einen Wert von einer MySQL-Funktion zurückgeben müssen, beispielsweise getLastRecord(name).

Traditionell verwendet Node.js Rückrufe für asynchrone Vorgänge. Um jedoch die asynchrone Natur von getLastRecord() zu bewältigen, nutzen wir Promises.

Um die Funktion mit einem Promise zu implementieren:

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
  });
}
Nach dem Login kopieren

Um den zurückgegebenen Wert zu verarbeiten, können Sie eine Kette verwenden .then()- und .catch()-Rückrufe auf das Versprechen:

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

Sie können auch die bedingte Prüfung implementieren:

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

Durch die Übernahme von Versprechen in diesem Szenario führen Sie eine ein Strukturierterer und lesbarerer Ansatz für die Handhabung asynchroner Vorgänge, der eine sauberere und besser wartbare Codebasis gewährleistet.

Das obige ist der detaillierte Inhalt vonWie behandelt man MySQL-Rückgabewerte asynchron in Node.js mit Versprechen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!