javascript
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 数据库的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python趣味编程_第6章 旋转的方块
- 下一篇: 26个音序的正确写法和占格_别让瞎练毁了