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, "项任务");
    }
  }
}
相关推荐
倔强的石头_16 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神2 天前
三、用户与权限管理
数据库·mysql
源分享2 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_2 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
JAVA9652 天前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的
java·jvm·面试
DARLING Zero two♡2 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧2 天前
Oracle EXPLAIN PLAN
数据库·oracle