SQLite 3.44.0 发布!

SQLite 开发团队于 2023 年 11 月 01 日发布了 SQLite 3.44.0 版本,带来了一些 SQL 和优化器增强,本文给大家做一个简要分分析。

新增 concat() 函数

新版本增加了两个连接字符串的函数:concat() 以及 concat_ws()。它们可以兼容 PostgreSQL、SQLServer 以及 MySQL,例如:

sql 复制代码
sqlite> select concat('sql', 'ite');
sqlite
sqlite> select concat_ws('-','S', 'Q', 'L');
S-Q-L

新增 string_agg() 函数

SQLite 提供了实现字符串聚合的 group_concat 函数,新版本为其增加了一个别名函数 string_agg(),目的是为了兼容 PostgreSQL 以及 SQL Server 语法。例如:

sql 复制代码
sqlite> create table test(pid int, val text);
sqlite> insert into test values(1, 'S'),(1,'Q'),(1,'L');
sqlite> select pid, string_agg(val,'-')
   ...> from test
   ...> group by pid;
1|S-Q-L

聚合函数 ORDER BY 子句

新版本支持在聚合函数中使用 ORDER BY 子句,指定数据在聚合函数中处理的顺序。这个参数对于某些聚合函数没有实际意义,例如 max();但是对于某些聚合函数,比如 string_agg() 以及 json_group_array(),该参数将会影响最终的结果。例如:

sql 复制代码
sqlite> select pid, string_agg(val,'-' order by val)
   ...> from test
   ...> group by pid;
1|L-Q-S

strftime() 新增参数

strftime() 函数增加了以下格式参数:

  • %e,返回月份中的第几天:0-31;
  • %F,ISO-8601 格式日期:YYYY-MM-DD;
  • %I,12小时制对应的小时:01-12;
  • %k,24 小时制对应的小时:0-24;
  • %l,12小时制对应的小时:1-12;
  • %p,代表上午和下午的"AM"和"PM";
  • %P,代表上午和下午的"am"和"pm";
  • %R,ISO-8601 格式时间:HH:MM;
  • %T,ISO-8601 格式时间:HH:MM:SS;
  • %u,一周中的第几天,1 代表星期一。

查询优化器

对于部分索引扫描,如果 WHERE 子句包含一个字段的常量值,那么可以用该常量替换该字段。这种优化增加了部分索引成为覆盖索引的可能性。

禁用了 3.42.0 版本增加的视图扫描优化,因为它导致了成倍的性能下降。

其他改进

新增了两个 C 语言 API:sqlite3_get_clientdata() 以及 sqlite3_set_clientdata()

CREATE TABLE 语句相关的许多错误在创建表时立即抛出,而不是等到该表第一次被访问时抛出。

PRAGMA integrity_check 命令使用新的 xIntegrity 方法验证各种内置虚拟表的内容一致性。该功能支持 FTS3、FTS4、FTS5、RTREE 以及 GEOPOLY 插件。

配置选项 SQLITE_DBCONFIG_DEFENSIVE 将会阻止启用 PRAGMA writable_schema 选项。在之前的版本中,writable_schema 可以被启用,但是不会实际生效。

内置 FTS3、FTS4、FTS5、RTREE 以及 GEOPOLY 虚拟表被设置为 SQLITE_VTAB_INNOCUOUS,因此它们可以在高安全部署环境中被用于触发器。

弃用 PRAGMA case_sensitive_like 语句,因为当模式包含 LIKE 操作符时会导致数据库被 PRAGMA integrity_check 损坏的报告。

当使用 Microsoft C 编译器时,默认启用 SQLITE_USE_SEH(结构化异常处理)。该选项可以使用 -DSQLITE_USE_SEH=0 禁用。

SQLite 在运行时检查底层硬件是否支持精度大于"double"的"long double"类型,并且基于检查结果使用相应的浮点数程序。

如果系统支持,Windows 命令行接口(CLI)默认使用 UTF-8 编码进行输入输出。使用 --no-utf8 选项启动可以禁用 UTF8 支持。

相关推荐
ohoy8 小时前
mysql 30天自动补0
数据库·mysql
摇滚侠10 小时前
Redis 零基础到进阶,Redis 哨兵监控,笔记63-73
数据库·redis·笔记
利剑 -~10 小时前
mysql面试题整理
android·数据库·mysql
老华带你飞10 小时前
物流信息管理|基于springboot 物流信息管理系统(源码+数据库+文档)
数据库·vue.js·spring boot
程序员卷卷狗10 小时前
Redis事务与MySQL事务有什么区别?一文分清
数据库·redis·mysql
玩大数据的龙威11 小时前
农经权二轮延包—数据(新老农经权)比对软件更新
数据库·arcgis
保持低旋律节奏11 小时前
网络系统管理——期末复习
数据库
程序员佳佳12 小时前
2025年大模型终极横评:GPT-5.2、Banana Pro与DeepSeek V3.2实战硬核比拼(附统一接入方案)
服务器·数据库·人工智能·python·gpt·api
roo_112 小时前
github 获取构造图数据库的LNB数据集和使用说明
数据库
罗汉松驻扎的工作基地13 小时前
sql server 2014 下载和安装
数据库