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, "项任务");
    }
  }
}
相关推荐
清风6666662 小时前
基于单片机的水塔液位检测与智能调节报警系统设计
数据库·单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
gplitems1232 小时前
Technox – IT Solutions & Services WordPress Theme: A Practical
linux·服务器·数据库
不剪发的Tony老师3 小时前
MySQL 9.5创新版发布,有哪些新功能?
数据库·mysql
布朗克1683 小时前
MySQL 及 SQL 注入详细说明
数据库·sql·mysql·1024程序员节
武子康4 小时前
Java-154 深入浅出 MongoDB 用Java访问 MongoDB 数据库 从环境搭建到CRUD完整示例
java·数据库·分布式·sql·mongodb·性能优化·nosql
Austindatabases4 小时前
DBA 从“修电脑的” 到 上演一套 “数据治理” 大戏 --- 维护DBA生存空间,体现个体价值
数据库·dba
LB21124 小时前
Redis黑马点评 day01
数据库·redis·缓存
白小筠5 小时前
创建Django项目
数据库·django·sqlite
扑克中的黑桃A6 小时前
金仓多模数据库平替MongoDB的电子证照国产化实践——从2TB数据迁移到1600+并发支撑
数据库
计算机毕业设计小帅6 小时前
【2026计算机毕业设计】基于Django的社区婴幼儿预防接种系统
数据库·django·课程设计