SQLite 3.4.60 版本发布,带来优化器和函数增强!

SQLite 开发团队于 2024 年 05 月 23 日发布了 SQLite 3.46.0 版本,带来了不少优化器和函数相关的增强,我们来了解一下新版本的改进功能。

优化数据库

新版本增强了 PRAGMA optimize 指令,简化了它的使用,具体包括:

  • PRAGMA optimize 可以自动设置一个合理的分析数量上限,避免大型数据库的 ANALYZE 操作时间过长。
  • 位掩码参数支持新的选项 0x10000。该选项表示检查所有的表大小,查看是否存在明显增长或者收缩的表,可以通过重新分析获取性能提升。
  • 自动重新分析没有 sqlite_stat1 记录的表。

日期时间函数

  • strftime() 函数增加了新的格式说明符 %G、%g、%U 以及 %V。
  • 日期时间函数增加了修饰符 ceiling(向上取整)和 floor(向下取整),用于解决日期增减整数月或者年时的歧义问题。例如 2024-02-29 增加 1 年应该是 2025-02-28 还是 2025-03-01 的问题。
  • 如果 SQLite 知道时间已经位于 UTC 或者 localtime,日期时间函数中的 utc 或者 localtime 修饰符不会执行任何操作。

查询优化器

  • "VALUES 子句协程"优化可以将包含数千个 VALUES 数据的 INSERT 语句的执行时间减少一半,同时占用的内存也减少一半。
  • 即使索引超过表的大小,仍然允许使用索引实现查询,例如"SELECT count(DISTINCT col) FROM ..."。
  • 当一个 SQL 函数的参数都是常量时,可以将函数的结果识别为常量。
  • 增强了 WHERE 子句下推优化,当 WHERE 子句中包含非关联子查询时可以使用条件下推。
  • 当 SQL 解析器堆栈溢出时,可以从堆内存中分配更多的内存,而不是返回"解析器堆栈溢出"错误。

JSON 相关

  • 增加了 json_pretty() 函数,美化输出,便于阅读。
  • JSON5 字符串常量支持 ASCII 控制字符。
  • 修复了 -> 以及 ->> 运算符,当它们右侧的参数是一个看起来像整数的字符串时,不再当作整数处理(\[N\]),而是当作字符串处理(.X)。这种方式和 PostgreSQL 实现一致。

常量字面值

  • 数字常量支持下划线(_),方便阅读。例如 10_000_000。
  • 允许使用大型十六进制常量作为表字段的默认值。
相关推荐
下班走回家10 小时前
向量数据库在 AI 应用中的角色:从 Milvus 到 Chroma
数据库·人工智能·milvus
TDengine (老段)10 小时前
TDengine SQL 解析与词法分析 — 从字符串到 AST 的转换之路
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据
StarRocks_labs10 小时前
StarRocks × Iceberg:联邦查询实践解析
数据库·starrocks·sql·iceberg·物化视图
IvorySQL10 小时前
PostgreSQL 技术日报 (6月7日)|峰会线上通道开放
数据库·postgresql
熊文豪10 小时前
SQL并行查询优化实践:从执行计划看并行能力的正确使用
数据库·sql·电科金仓
Ze3G90nYt10 小时前
Redis 分布式锁进阶第一百二十篇
数据库·redis·分布式
华山令狐虫10 小时前
DBAPI 接入 Milvus 向量数据库:HTTP 执行器参数映射实战
数据库·http·milvus·dbapi
Fuly102410 小时前
LangGraph学习-(1)跑通一个最小状态图
数据库·学习
计算机安禾10 小时前
【数据库系统原理】第5篇:关系的完整性约束:实体、参照与用户定义的逻辑守卫
数据库·oracle
snow@li10 小时前
数据库:Schema = 数据库的“蓝图“或“命名空间“
数据库