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, "项任务");
    }
  }
}
相关推荐
bing_1585 分钟前
如何合理设计缓存 Key的命名规范,以避免在共享 Redis 或跨服务场景下的冲突?
数据库·redis·缓存
健康平安的活着15 分钟前
mysql数据库实现分库分表,读写分离中间件sharding-sphere
数据库·mysql·中间件
黑客笔记33 分钟前
安全大模型的思考
数据库·安全·web安全
穗余1 小时前
NodeJS全栈开发面试题讲解——P3数据库(MySQL / MongoDB / Redis)
数据库·mysql·node.js
切糕师学AI1 小时前
SQL 筛选出在表1但不在表2中的数据
数据库·sql
ontheway-xx1 小时前
MongoDB账号密码笔记
数据库·mongodb
雨落倾城夏未凉2 小时前
数据库编程应用--创建专题1
数据库
Leo.yuan3 小时前
数据安全中心是什么?如何做好数据安全管理?
大数据·运维·网络·数据库·数据仓库
文牧之3 小时前
PostgreSQL的扩展 auth_delay
运维·数据库·postgresql
微风轻吟挽歌3 小时前
TIDB创建索引失败 mkdir /tmp/tidb/tmp_ddl-4000/1370: no such file or directory.
数据库·oracle·tidb