当前位置: 首页 > news >正文

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

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

一、模块启用与导入

  • 启用方式node:sqlite 模块目前处于活跃开发阶段,需要通过 --experimental-sqlite CLI 标志来启用。
  • 导入方式:使用 import 语句从 node:sqlite 模块中导入所需的类和方法。例如:
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 语句,不返回结果。
    • 示例
database.exec(`CREATE TABLE data(key INTEGER PRIMARY KEY,value TEXT) STRICT
`);
  • database.prepare(sql)
    • 作用:创建预处理语句,用于高效执行重复的 SQL 操作。
    • 示例
const insert = database.prepare('INSERT INTO data (key, value) VALUES (?, ?)');
insert.run(1, 'hello');
insert.run(2, 'world');
  • database.close()
    • 作用:关闭数据库连接。
    • 示例
database.close();

三、使用示例

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

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 语句执行错误等。
http://www.dtcms.com/a/264691.html

相关文章:

  • LeetCode 377.组合总和IV
  • 【算法】动态规划:python实现 2
  • 【APB协议时序及示例】
  • 2025美国券商交易系统综合开发及解决方案报告:低延迟、全球化与代币化技术赋能机构业务新生态
  • 摄像头AI智能识别工程车技术及应用前景展望
  • 武汉大学机器人学院启航:一场颠覆性的产教融合实验,如何重塑中国智造未来?
  • 【seismic unix数据处理--suvcat】
  • drawRect 触发时机
  • [特殊字符] Excel 提取+图片批量插入 | Python 自动化生成稽查报告 Word 模板
  • ubuntu 22.04 LTS 安装preempt-rt
  • pytorch底层原理学习--JIT与torchscript
  • 开机自动后台运行,在Windows服务中托管ASP.NET Core
  • 企业培训笔记:SpringBoot+MyBatis项目中实现分页查询
  • GraphPrompts:图神经网络领域的提示工程范式革新者
  • 学习笔记(28):随机噪声的原理、作用及代码实现详解
  • CC - Link IE转EtherCAT:石油石化软启动器的“最佳搭子”
  • 电商项目实例:基于Python京东商品API接口数据采集
  • 跨越传统界限:ChatGPT+ENVI/Python/GEE集成实战,覆盖无人机遥感、深度学习、洪水监测、矿物识别填图、土壤含水量评估等
  • 【Web前端】优化轮播图展示(源代码)
  • MDK(Keil MDK)工具链
  • cmake find_package
  • C++ 创建动态库及两种方法调用动态库
  • DINO 浅析
  • 医学+AI教育实践!南医大探索数据挖掘人才培养,清华指导发布AI教育白皮书
  • HarmonyOS应用开发高级认证知识点梳理 (四)状态管理V2应用级状态
  • AutoGen-AgentChat-1-整体了解
  • NestJS 系列教程(一):认识 NestJS 与项目初始化
  • RabbitMQ 高级特性之持久性
  • OpenCV仿射变换详解
  • 【飞算JavaAI】智能开发助手赋能Java领域,飞算JavaAI全方位解析