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!