nodejs sqlite模块

SQLite 是一个轻量级的嵌入式数据库,它在 Node.js 中的使用通常是异步的。这意味着当你执行数据库操作时,例如创建表、插入数据或查询数据,这些操作会被放入事件队列中异步执行,而不会阻塞主线程。

安装sqlite3

bash 复制代码
npm install sqlite3

安装出错,以前没这个问题,这次出错了。最后发现是版本问题,对于 node 10.x 及更高版本,只需安装sqlite3@4.1.1 ,问题解决。

bash 复制代码
npm install sqlite3@4.1.1

如果没有解决你的问题,可以试下网上说的一些方法。

I had same issue. Steps below should solve It on windows:

  1. You should install Windows Build Tools globally before install gyp
    npm i --global --production windows-build-tools
  2. Install Node Gyp
    npm i -g node-gyp
  3. Clear NPM Cache
    npm cache clean
  4. Try to install SQLite again
    npm i sqlite3

相关资料:

使用示例

javascript 复制代码
import sqlite3 from 'sqlite3';
let db = new sqlite3.Database('mydatabase.db');
// 创建一个名为users的表格
db.serialize(() => {
    db.run("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY, name TEXT)");

    // 插入一些数据
    db.run("INSERT INTO users (name) VALUES (?)", ['Alice']);
    db.run("INSERT INTO users (name) VALUES (?)", ['Bob']);

    // 查询数据
    db.all("SELECT * FROM users", (err, rows) => {
        if (err) {
            throw err;
        }
        rows.forEach(row => {
            console.log(row.id, row.name);
        });
    });
    console.log('ok');
});

// 关闭数据库连接
db.close();

在使用 SQLite 操作数据库时,使用 db.serialize() 可以确保在执行多个查询时,它们按顺序执行。这对于确保某些查询在其他查询完成后再执行是很重要的。比如创建表和插入数据,如果不使用 db.serialize(),可能会导致操作的执行顺序混乱,从而引发错误或逻辑上的混乱。

db.serialize() 并不是将其中的操作变成同步执行,而是确保其中的操作按照顺序执行,从而避免并发执行带来的问题。需要理解的是,虽然代码是按顺序写的,但是数据库操作本身是异步的。这意味着每个数据库操作会被放入事件队列中,然后在适当的时机被执行,而不是立即阻塞执行。因此,在执行一系列数据库操作时,你并不能保证它们会严格按照你代码中的顺序立即执行完毕,可能会有一些微小的时间差异。

常用API方法:

  • new sqlite3.Database(filename [, mode], [, callback]):打开或创建一个数据库文件。
  • db.run(sql [, params], [, callback]):执行一个SQL语句,如INSERT、UPDATE或DELETE。
  • db.get(sql [, params], callback):执行一个SELECT查询,并返回一行数据。
  • db.all(sql [, params], callback):执行一个SELECT查询,并返回所有匹配的行。
  • db.each(sql [, params], callback):执行 SELECT 查询,并逐行处理查询结果。
  • db.exec(sql [, callback]):执行多条 SQL 语句,并在一次调用中处理这些语句。
相关推荐
这个DBA有点耶3 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶5 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技5 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend6 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence9 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql