日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

nodejs sqlite3_NodeJS 使用 better-sqlite3 操作sqlite 数据库

發布時間:2025/3/15 javascript 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 nodejs sqlite3_NodeJS 使用 better-sqlite3 操作sqlite 数据库 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

背景

NodeJS web server 開發中總要操作數據的,對于輕量級的應用 選用 sqlite 存儲是比較方便實用的。我們選用 better-sqlite3 這個庫操作數據庫。

最方便的一點是,它是同步的。對比于原sqlite3類庫更適合配合 koa2 一起使用。代碼會變得更簡單易讀。

為什么選用 better-sqlite3 而 不直接選用 sqlite3

Node.js中SQLite3最快最簡單的庫。

  • 完整的事務支持
  • 高性能,高效率和安全性
  • 易于使用的同步API (比異步API更快......是的,你讀得正確)
  • 支持用戶定義的函數,聚合和擴展
  • 64位整數(在您需要它們之前不可見)

下圖是個性能對比,能看出來性能 better-sqlite3 優于 sqlite3 。

image.png

安裝

npm install --save better-sqlite3

使用

const db = require('better-sqlite3')('foobar.db', options);

const row = db.prepare('SELECT * FROM users WHERE id=?').get(userId);

console.log(row.firstName, row.lastName, row.email);

我的代碼示例

const TAG = '## TokenDao: ';

class TokenDao {

constructor(db) {

this.db = db;

this.saveUserToken = this.saveUserToken.bind(this);

}

getUserToken(username,appType){

var stmt = this.db.prepare('select userID,username,tokenString from UserToken where username=? and appType=?');

var row = stmt.get(username,appType);

console.log('getUserToken: '+JSON.stringify(row));

return row;

}

saveUserToken(username,appType,tokenString ) {

var stmt = this.db.prepare('select userID,username,tokenString from UserToken where username=? and appType=?');

var row = stmt.get(username,appType);

if(row){

console.log('存在,則更新');

//存在,則更新

var stmt = this.db.prepare("update UserToken set tokenString = ? where username=? and appType=?");

stmt.run(tokenString,username, appType);

}else{

console.log('不存在,則插入');

//不存在,則插入

var stmt = this.db.prepare("INSERT INTO UserToken (userName,appType,tokenString) VALUES (?,?,?)");

stmt.run(username, appType,tokenString);

}

}

}

module.exports = TokenDao;

參考

https://github.com/JoshuaWise/better-sqlite3

總結

以上是生活随笔為你收集整理的nodejs sqlite3_NodeJS 使用 better-sqlite3 操作sqlite 数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。