sqlite3的封装

bash 复制代码
cnpm i sqlite3

db.js

javascript 复制代码
// const sqlite3 = require('sqlite3').verbose()
import { Database } from 'sqlite3'
function getDB(dbPath, mCreateTableSql) {
  let createTableSql  = mCreateTableSql
  const setCreateTableSql = (sql) => (createTableSql = sql)
  const setDBPath = (path) => (dbPath = path)

  const db = new Database(dbPath)
  const executeSql = (sql, params) => {
    return new Promise((resolve, reject) => {
      db.run(createTableSql, (err) => {
        if (err) {
          reject(err)
        } else {
          db.all(sql, params, (err, rows) => {
            if (err != null) {
              console.log('sqlite error', err)
              reject(err)
            } else {
              console.log('sqlite success')
              resolve(rows)
            }
          })
        }
      })
    })
  }
  const showTables = async () => {
    return await executeSql('SELECT name FROM sqlite_master WHERE type="table";', [])
  }
  return {
    showTables,
    setCreateTableSql,
    setDBPath,
    executeSql
  }
}

export default getDB

使用db

javascript 复制代码
import getDB from './db.js'
const tableSql=
  'CREATE TABLE IF NOT EXISTS tableName(' +
  'id INTEGER PRIMARY KEY AUTOINCREMENT,' +
  '`name` TEXT NOT NULL);'
const { showTables, setCreateTableSql, setDBPath, executeSql } = getDB("D:/database.db", tableSql)

const test = async () => {
  // const data = await executeSql("select * from tableName", []);
  const data = await executeSql("select * from tableName where name = ?", ['name']);// 传递参数
  const tables = await showTables();
  console.log(tables)
}
test();

踩坑记录:

使用异步函数,想要控制并发数量时,不要不要不要使用 数组对象 的 forEach方法,用for循环就没问题

javascript 复制代码
async function fun() {
  let tasks = [];
  const taskLimit = 10; // 限制并发数量
  for (let k = 0; k < arr.length; k++) {
    tasks.push(asyncFun(arr[k],globalVar));// 把变量传递给函数调用,防止变量被某个异步函数修改
    if (tasks.length >= taskLimit) {
      await Promise.all(tasks);
      tasks = [];
      console.log("已异步执行", taskLimit, "项任务");
    }
  }
}
相关推荐
徐子童11 分钟前
JVM高频面试题---GC垃圾回收
java·开发语言·jvm·面试题·gc·垃圾回收算法
我有一颗五叶草12 分钟前
JVM-垃圾回收
jvm
StevenGerrad21 分钟前
【读书笔记】深入理解JVM C6-9 虚拟机执行子系统
java·jvm
0wioiw026 分钟前
PostgreSQL(②基础命令)
数据库·postgresql
aloha_78928 分钟前
新国都面试真题
jvm·spring boot·spring·面试·职场和发展
xcLeigh1 小时前
KingbaseES数据库:兼容 SQL 语法及 Oracle 过程化语言的语法基础
数据库
FinTech老王1 小时前
一场“无感换心”手术:金仓数据库如何让电子证照系统平滑告别MongoDB
数据库·mongodb
周杰伦的稻香1 小时前
MySQL中的空间碎片率计算分析
android·数据库·mysql
重启的码农1 小时前
kv数据库-leveldb (13) 缓存 (Cache)
数据库
重启的码农1 小时前
kv数据库-leveldb (12) 数据块 (Block)
数据库