新聞中心
前言
創(chuàng)新互聯(lián)建站是專業(yè)的上城網(wǎng)站建設(shè)公司,上城接單;提供網(wǎng)站設(shè)計(jì)、做網(wǎng)站,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行上城網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
本文主要給大家介紹的是關(guān)于Node.js對(duì)SQLite的async/await封裝的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧
用于將每個(gè)SQLite函數(shù)同步化,并可以用await的接口。
注意:需要SQLite for Node模塊和Node.js 8.0+,并支持async / await。
SQLite最常用作本地或移動(dòng)應(yīng)用程序的存儲(chǔ)單元,當(dāng)需要從程序的各個(gè)部分訪問數(shù)據(jù)時(shí),回調(diào)不是最佳解決方案。
為了在程序程序中更自然地訪問數(shù)據(jù),我編寫了一個(gè)將回調(diào)轉(zhuǎn)換為promises的接口,因此我們可以將每個(gè)函數(shù)與await關(guān)鍵字一起使用。 它不是異步函數(shù)的替代品,它是一個(gè)補(bǔ)充,可以將原始函數(shù)和同步函數(shù)一起使用。
aa-sqlite模塊
SQLite的接口是一個(gè)名為aa-sqlite的模塊,您必須將其存儲(chǔ)在應(yīng)用程序的node_modules部分中。這是完整的源代碼
const sqlite3 = require('sqlite3').verbose() var db exports.db = db exports.open=function(path) { return new Promise(function(resolve) { this.db = new sqlite3.Database(path, function(err) { if(err) reject("Open error: "+ err.message) else resolve(path + " opened") } ) }) } // any query: insert/delete/update exports.run=function(query) { return new Promise(function(resolve, reject) { this.db.run(query, function(err) { if(err) reject(err.message) else resolve(true) }) }) } // first row read exports.get=function(query, params) { return new Promise(function(resolve, reject) { this.db.get(query, params, function(err, row) { if(err) reject("Read error: " + err.message) else { resolve(row) } }) }) } // set of rows read exports.all=function(query, params) { return new Promise(function(resolve, reject) { if(params == undefined) params=[] this.db.all(query, params, function(err, rows) { if(err) reject("Read error: " + err.message) else { resolve(rows) } }) }) } // each row returned one by one exports.each=function(query, params, action) { return new Promise(function(resolve, reject) { var db = this.db db.serialize(function() { db.each(query, params, function(err, row) { if(err) reject("Read error: " + err.message) else { if(row) { action(row) } } }) db.get("", function(err, row) { resolve(true) }) }) }) } exports.close=function() { return new Promise(function(resolve, reject) { this.db.close() resolve(true) }) }
使用示例
下面的示例展示了aa-sqlite的每個(gè)功能的示例。在第一部分中,我們打開一個(gè)數(shù)據(jù)庫(kù),添加一個(gè)表并用一些行填充該表。然后關(guān)閉數(shù)據(jù)庫(kù),我們?cè)俅未蜷_它并執(zhí)行一些同步查詢。
const fs = require("fs") const sqlite = require("aa-sqlite") async function mainApp() { console.log(await sqlite.open('./users.db')) // Adds a table var r = await sqlite.run('CREATE TABLE users(ID integer NOT NULL PRIMARY KEY, name text, city text)') if(r) console.log("Table created") // Fills the table let users = { "Naomi": "chicago", "Julia": "Frisco", "Amy": "New York", "Scarlett": "Austin", "Amy": "Seattle" } var id = 1 for(var x in users) { var entry = `'${id}','${x}','${users[x]}'` var sql = "INSERT INTO users(ID, name, city) VALUES (" + entry + ")" r = await sqlite.run(sql) if(r) console.log("Inserted.") id++ } // Starting a new cycle to access the data await sqlite.close(); await sqlite.open('./users.db') console.log("Select one user:") var sql = "SELECT ID, name, city FROM users WHERE name='Naomi'" r = await sqlite.get(sql) console.log("Read:", r.ID, r.name, r.city) console.log("Get all users:") sql = "SELECT * FROM users" r = await sqlite.all(sql, []) r.forEach(function(row) { console.log("Read:", row.ID, row.name, row.city) }) console.log("Get some users:") sql = "SELECT * FROM users WHERE name=?" r = await sqlite.all(sql, ['Amy']) r.forEach(function(row) { console.log("Read:", row.ID, row.name, row.city) }) console.log("One by one:") sql = "SELECT * FROM users" r = await sqlite.each(sql, [], function(row) { console.log("Read:", row.ID, row.name, row.city) }) if(r) console.log("Done.") sqlite.close(); } try { fs.unlinkSync("./users.db") } catch(e) { } mainApp()
由于all方法返回一個(gè)row數(shù)組,我們使用forEach來處理每一行的內(nèi)容。
你可以在每個(gè)方法的情況下進(jìn)行驗(yàn)證,即在程序顯示“完成”之前處理返回的每一行。原始異步方法不會(huì)出現(xiàn)這種情況。
參考并翻譯自:https://www.scriptol.com/sql/sqlite-async-await.php
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。
文章標(biāo)題:Node.js如何對(duì)SQLite的async/await封裝詳解
分享鏈接:http://fisionsoft.com.cn/article/gsgiss.html