SQLite Release 3.52.0发布,有哪些新功能?

SQLite 开发团队于 2026 年 03 月 06 日发布了 SQLite 3.52.0 版本,带来了以下新功能和性能优化增强。

  1. 修复了一个导致 WAL 重置时数据库损坏的 bug。
  2. 增强 ALTER TABLE 语句,支持添加和删除 NOT NULL 以及 CHECK 约束。
  3. 新增查询结果格式化库(QRF) ,用于格式化 SQL 查询结果,使其在等宽字体屏幕上更易于人类阅读;TCL 接口中添加了 format 方法,使得 TCL 可以调用 QRF;命令行接口(CLI)中使用 QRF 进行结果格式化,从而提升了显示效果。
  4. 新增内置 SQL 函数:json_array_insert()和jsonb_array_insert(),用于在 JSON 数据中插入元素。
  5. CLI 的改造与增强
    • .mode 命令得到大幅增强。
    • 基于 QRF 扩展改进了结果格式化。例如,在表格输出模式下,数值现在默认右对齐。
    • 交互式 CLI 会话的默认输出模式使用 QRF,利用 Unicode 制表符绘制方框来显示查询结果,提高了可读性。批处理 CLI 会话为保持兼容性,仍使用旧式输出格式。
    • 点命令末尾未加引号的分号会被忽略,这是一个潜在的不兼容变更。
    • 修复了 .testcase.check 命令使其真正生效,并且在作为源代码一部分的标准 SQLite 测试套件脚本中使用了这些命令。
    • 匹配 *.sql*.txt 模式且为非空文件名的命令行参数,现在会被读取并解释为包含 SQL 语句和/或点命令的脚本。
    • .timer 命令现在可以接受 once 参数,表示仅对下一条 SQL 语句运行计时功能。
    • .progress 命令新增了 --timeout S 选项,可在 SQL 语句执行超过 S 秒后将其中断。
  6. 新增 C 语言接口
    • sqlite3_str_truncate()
    • sqlite3_str_free()
    • sqlite3_carray_bind_v2()
    • sqlite3_prepare_v3() 增加了 SQLITE_PREPARE_FROM_DDL 选项,允许虚拟表实现可以安全地从数据库模式生成 SQL 语句。
    • 增加了 SQLITE_UTF8_ZT 常量,可以作为 sqlite3_result_text64()sqlite3_bind_text64() 的编码参数,表明该值采用 UTF-8 编码并且以零结尾。
    • sqlite3_limit() 增加了 SQLITE_LIMIT_PARSER_DEPTH 选项。
    • sqlite3_db_config() 增加了 SQLITE_DBCONFIG_FP_DIGITS 选项(参见下文第 8 项)。
  7. 查询计划器的改进
    • 对于 EXCEPTINTERSECT 以及 UNION 操作,始终使用排序合并算法,因为这在大多数情况下比使用哈希表更快。
    • 改进了星型模式中大規模多路连接的连接顺序选择。
    • 增强了 EXISTS-JOIN 优化,只要 EXISTS-JOIN 循环的所有依赖都在外层循环中,插入的 JOIN 项就不再强制要求在最内层循环。
    • 增强了(omit-noop-join)优化,使其能够忽略不影响输出结果的连接操作。
    • 允许对使用 GROUP BY e1 ORDER BY e2(其中 e1 和 e2 除了 ASC/DESC 排序方向外完全相同)的查询使用单个索引进行优化。
    • 允许虚拟表在查询结果集不完全匹配 ORDER BY 子句的情况下对 DISTINCT 进行优化。
  8. 浮点数与文本之间转换的改进 :重新实现了转换逻辑以提升性能;默认情况下,四舍五入保留 17 位有效数字,此前所有版本均为 15 位。如有需要,可以使用 sqlite3_db_config(SQLITE_DBCONFIG_FP_DIGITS) API(上文第 6 项)更改此设置。
  9. TEMP 触发器的主体现在可以修改和/或查询主数据库模式中的表。
  10. 增强 VACUUM INTO 命令 :如果目标文件使用 URI 文件名,并且该文件名包含 reserve=N(N 在 0 到 255 之间)查询参数,则生成的数据库副本保留数量将设置为 N。
  11. sqlite3_rsync 工具增加了 -p|--port 选项。
  12. 停止支持 Windows RT

完整的发行说明可以参考官方文档:

https://www.sqlite.org/releaselog/3_52_0.html

相关推荐
运维行者_3 小时前
企业无线网络监控的挑战与智能化演进趋势
大数据·运维·服务器·网络·数据库
国强_dev3 小时前
技术探讨:使用 stunnel 加密转发数据库连接时,如何获取客户端真实 IP?
数据库·网络协议·tcp/ip
@insist1233 小时前
系统规划与管理师-信息系统规划核心工作要点解析
数据库·软考·系统规划与管理师·软件水平考试·系统规划与管理工程师
超级数据查看器3 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
数安3000天4 小时前
增量数据如何自动分类分级,避免目录“过期“?
大数据·数据库
南墙上的石头5 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql
画中有画6 小时前
论向量数据库在项目中的应用
数据库
spider_xcxc6 小时前
Redis 数据库高质量实践指南(一)
运维·数据库·redis·oracle·云计算
l1t7 小时前
在linux和windows中解决duckdb 1.6dev版本输出执行计划报错问题
linux·运维·数据库·windows·duckdb
执子手 吹散苍茫茫烟波7 小时前
RC 隔离级别下 MySQL InnoDB 死锁典型案例
数据库·mysql