nodejs sqlite模块

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

安装sqlite3

bash 复制代码
npm install sqlite3

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

bash 复制代码
npm install [email protected]

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

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 语句,并在一次调用中处理这些语句。
相关推荐
数据智能老司机2 小时前
CockroachDB权威指南——SQL调优
数据库·分布式·架构
数据智能老司机2 小时前
CockroachDB权威指南——应用设计与实现
数据库·分布式·架构
数据智能老司机2 小时前
CockroachDB权威指南——CockroachDB 模式设计
数据库·分布式·架构
数据智能老司机21 小时前
CockroachDB权威指南——CockroachDB SQL
数据库·分布式·架构
数据智能老司机21 小时前
CockroachDB权威指南——开始使用
数据库·分布式·架构
松果猿1 天前
空间数据库学习(二)—— PostgreSQL数据库的备份转储和导入恢复
数据库
无名之逆1 天前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
s9123601011 天前
rust 同时处理多个异步任务
java·数据库·rust
数据智能老司机1 天前
CockroachDB权威指南——CockroachDB 架构
数据库·分布式·架构
hzulwy1 天前
Redis常用的数据结构及其使用场景
数据库·redis