Node.js v22.5+ 官方 SQLite 模块全解析:从入门到实战

在 Node.js v22.5.0 及更高版本中,node:sqlite 模块作为内置模块被引入,为开发者提供了与 SQLite 数据库交互的官方支持。以下是关于 node:sqlite 模块的详细介绍:

一、模块启用与导入

  • 启用方式node:sqlite 模块目前处于活跃开发阶段,需要通过 --experimental-sqlite CLI 标志来启用。
  • 导入方式 :使用 import 语句从 node:sqlite 模块中导入所需的类和方法。例如:
javascript 复制代码
import { DatabaseSync } from 'node:sqlite';

二、核心类与方法

1. DatabaseSync
  • 作用:表示与 SQLite 数据库的单连接,所有 API 均同步执行。
  • 构造函数new DatabaseSync(location[, options])
    • location :数据库位置,可以是文件路径(如 './mydb.sqlite')或内存标识(如 ':memory:')。
    • options :配置选项,包括是否自动打开数据库(open)、是否启用外键约束(enableForeignKeyConstraints)等。
2. 常用方法
  • database.exec(sql)
    • 作用:执行一条或多条 SQL 语句,不返回结果。
    • 示例
javascript 复制代码
database.exec(`
  CREATE TABLE data(
    key INTEGER PRIMARY KEY,
    value TEXT
  ) STRICT
`);
  • database.prepare(sql)
    • 作用:创建预处理语句,用于高效执行重复的 SQL 操作。
    • 示例
javascript 复制代码
const insert = database.prepare('INSERT INTO data (key, value) VALUES (?, ?)');
insert.run(1, 'hello');
insert.run(2, 'world');
  • database.close()
    • 作用:关闭数据库连接。
    • 示例
javascript 复制代码
database.close();

三、使用示例

以下是一个完整的示例,展示了如何使用 node:sqlite 模块进行数据库操作:

javascript 复制代码
import { DatabaseSync } from 'node:sqlite';

// 创建或打开内存数据库
const database = new DatabaseSync(':memory:');

// 创建表
database.exec(`
  CREATE TABLE data(
    key INTEGER PRIMARY KEY,
    value TEXT
  ) STRICT
`);

// 插入数据
const insert = database.prepare('INSERT INTO data (key, value) VALUES (?, ?)');
insert.run(1, 'hello');
insert.run(2, 'world');

// 查询数据
const query = database.prepare('SELECT * FROM data ORDER BY key');
console.log(query.all()); // 输出: [ { key: 1, value: 'hello' }, { key: 2, value: 'world' } ]

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

四、注意事项

  • 实验性特性node:sqlite 模块目前处于实验性阶段,API 可能在未来版本中发生变化。
  • 同步执行DatabaseSync 类的所有方法均同步执行,可能会阻塞事件循环。对于高并发场景,建议考虑使用异步数据库驱动(如 sqlite3 模块)。
  • 错误处理 :在使用 node:sqlite 模块时,应妥善处理可能出现的错误,如数据库连接失败、SQL 语句执行错误等。
相关推荐
瀚高PG实验室13 分钟前
逻辑导入导出(pg_dump/pg_restore)用法2-导入到不同的schema或tablespace
数据库·瀚高数据库
whyfail19 分钟前
前端数据存储新选择:IndexedDB与Dexie.js技术指南
前端·javascript·数据库
煎蛋学姐22 分钟前
SSM校园快递系统q9061(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·开题报告·java 开发·校园信息化·ssm 框架
元亓亓亓32 分钟前
考研408--操作系统--day11--文件管理&逻辑物理结构&目录&存储空间管理
数据库·考研·文件管理·408
cly11 小时前
Ansible自动化(十三):调试与优化
数据库·自动化·ansible
QQ_4376643141 小时前
redis相关命令讲解及原理
数据库·redis·缓存
萤丰信息1 小时前
开启园区“生命体”时代——智慧园区系统,定义未来的办公与生活
java·大数据·运维·数据库·人工智能·生活·智慧园区
TDengine (老段)2 小时前
TDengine Rust 连接器进阶指南
大数据·数据库·物联网·rust·时序数据库·tdengine·涛思数据
二哈喇子!2 小时前
MySQL数据库操作命令【SQL语言】
数据库·sql·视图与索引
China_Yanhy2 小时前
AWS S3 深度配置指南:每一栏每个选项有什么作用
java·数据库·aws