在 electron+vite+vue3+express 项目中使用better-sqlite3

文章目录

      • [一、安装 electron-rebuild 和 better-sqlite3](#一、安装 electron-rebuild 和 better-sqlite3)
      • [二、使用 electron-rebuild 重建 Node.js 模块](#二、使用 electron-rebuild 重建 Node.js 模块)
      • [三、better-sqlite3 的基本使用](#三、better-sqlite3 的基本使用)
      • 四、打包
      • 五、参考资料

一、安装 electron-rebuild 和 better-sqlite3

复制代码
yarn add -D electron-rebuild
yarn add better-sqlite3

Electron 内置的 Node.js 版本和编译到 better-sqlite3 的 Node.js 版本不同将可能导致安装失败,所以此处需要安装 electron-rebuild 重建 Node.js 模块。(注意安装顺序,否则可能出现安装失败的问题)

二、使用 electron-rebuild 重建 Node.js 模块

如果安装完 better-sqlite3 不重建直接运行,则可能出现以下报错:

shell 复制代码
Error: The module 'xxx'
was compiled against a different Node.js version using
NODE_MODULE_VERSION xxx. This version of Node.js requires
NODE_MODULE_VERSION xxx. Please try re-compiling or re-installing
the module (for instance, using `npm rebuild` or `npm install`).

修改 package.json 文件中的 scripts 内容:

json 复制代码
  "scripts": {
    "dev": "vite",
    ...
    "rebuild": "electron-rebuild -f -w better-sqlite3"
  },

执行命令:yarn run rebuild 重建 Node.js 版本。

三、better-sqlite3 的基本使用

新建 db/DBManager.ts 文件:

ts 复制代码
const sqliteDB = require('better-sqlite3');
const path = require('path');

const dbPath = 
    process.env.NODE_ENV === "development" ? 
    "./wallpapers.db" : path.join(process.resourcesPath, "./wallpapers.db")

// 打开数据库,如果不存在则创建,cacheSize 缓存数据最大值
const db = new sqliteDB(dbPath,{ cacheSize: 15 });
db.pragma('journal_mode = WAL');

exports.db = db;

新建 db/ImageManager.ts 文件:

ts 复制代码
const dbmgr = require("./DBManager.ts");
const db = dbmgr.db;

// 读取信息
const readAllImgs = () => {
    try {
        const result = db.prepare("SELECT * FROM imgs", { cached: true }).all();
        return result;
    } catch (error) {
        console.error(error);
        throw error;
    }
};

// 批量插入数据 (values 是一个对象)
const insertWallhaven = (keys, values) => {
    try {
        // 使用命名参数 例: $id、$url ... ; 数据 values => [{id: xx, url: xx},{}]
        // 由于插入的数据 id 可能重复,所以此处使用 OR IGNORE
        const insertQuery = db.prepare(
            `INSERT OR IGNORE INTO wallhaven (${keys.join(",")}) VALUES (${keys.map((item) => "$" + item).join(",")})`
        );
        const insertMany = db.transaction((values) => {
            for (const val of values) {
                insertQuery.run(val)
            }
        });
        insertMany(values);
    } catch (error) {
        console.error(error);
        throw error;
    }
};

module.exports = {
    readWallhaven,
    insertWallhaven,
};

四、打包

修改 electron-builder.json5 文件,添加打包配置:

json 复制代码
  "directories": {
    ...
  },
  // 添加数据库文件
  "extraResources": [
    "./wallpapers.db"
  ],

将数据库文件放在根目录下:


说明: 后续在使用过程中发现,每次安装新的第三方库时都需要重新执行 yarn run rebuild 命令重建 Node.js 模块,否则可能出现报错。

五、参考资料

相关推荐
芒鸽5 小时前
鸿蒙PC应用开发系列之Electron篇:开发环境搭建
华为·electron·harmonyos
a_eastern5 小时前
linux electron-forge离线打包关键配置
android·linux·electron
PascalMing5 小时前
Pascal.Edge物联网平台:生产企业设备数据采集与管理解决方案
物联网·c#·vue·数据采集
龙国浪子5 小时前
从点到线,从线到画:Canvas 画笔工具的实现艺术
前端·electron
代码游侠6 小时前
学习笔记——sqlite3 数据库基础
linux·运维·网络·数据库·笔记·学习·sqlite
程序员王天6 小时前
SQLite 索引智能构建:从每次启动30秒到秒开
前端·oracle·electron·sqlite
Dreamcatcher_AC6 小时前
Node.js留言板开发全流程解析
前端·javascript·mysql·node.js·express
启扶农7 小时前
lecen:一个更好的开源可视化系统搭建项目--介绍、搭建、访问与基本配置--全低代码|所见即所得|利用可视化设计器构建你的应用系统-做一个懂你的人
低代码·vue·node·所见即所得·表单设计·页面可视化·页面设计器
爱分享的小诺7 小时前
在谷歌浏览器上的谷歌商店进不去,可以使用...
vue·谷歌浏览器·扩展插件
贺今宵18 小时前
安装better-sqlite3报错electron-vite
javascript·sql·sqlite·sqlite3