• SQLite 3.43.0 发布,又有啥新功能?


    SQLite 开发团队于 2023 年 08 月 24 日发布了 SQLite 3.43.0 版本。本文给大家分析一下该版本的更新。

    全文索引

    SQLite 3.43.0 增加了 Contentless-Delete FTS5 索引。这是一种 FTS5 全文索引的变种,不存储被索引的内容,同时支持数据的删除操作

    例如:

    CREATE VIRTUAL TABLE f1 USING fts5(a, b, c, content='', contentless_delete=1);
    
    • 1

    Contentless-delete 表与 Contentless 表的区别在于:

    • Contentless-delete 表支持 DELETE 以及 INSERT OR REPLACE INTO 语句;
    • Contentless-delete 表支持 UPDATE 语句,前提是所有用户定义的字段都指定了新的数据;
    • Contentless-delete 表不支持 FTS5 删除命令

    例如:

    -- 支持以下 UPDATE 语句
    UPDATE f1 SET a=?, b=?, c=? WHERE rowid=?;
    
    -- 不支持以下 UPDATE 语句,因为字段 c 没有指定新的数据
    UPDATE f1 SET a=?, b=? WHERE rowid=?;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    除非存在旧版本的后向兼容需求,推荐使用 Contentless-delete 表。

    日期时间函数

    新版本增强了日期时间相关的函数。首先是增加了“±YYYY-MM-DD HH:MM:SS.SSS”形式的时间偏移量,例如:

    select date('2023-01-01', '+1000-01-01');
    3023-02-02
    
    • 1
    • 2

    其次,新版本增加了 timediff(A, B) 函数,计算从时间 B 到达时间 A 所需的时间。例如:

    select timediff('2023-06-01', '2023-01-01');
    +0000-05-00 00:00:00.000
    
    • 1
    • 2

    timediff() 函数返回的格式是字符串,方便阅读。如果想要返回精确的时间差(天数、秒数等),可以使用两个 julianday() 或 unixepoch() 函数相减。

    字符串函数

    SQLite 3.43.0 增加了一个 octet_length(X) 字符串函数,用于返回字符串 X 占用的字节数。例如:

    select octet_length('Hello');
    5
    
    select octet_length('你好');
    6
    
    • 1
    • 2
    • 3
    • 4
    • 5

    octet_length(X) 以字节为单位,而不是字符为单位。因此,不同数据库字符集可能返回不同的长度。

    C 语言接口

    SQLite 3.43.0 新增了一个 sqlite3_stmt_explain(S,E) API,用于改变预编译语句的 EXPLAIN 设置。

    如果参数 E 设置为 0,S 就是一个普通的预编译语句;如果 E 设置为 1,S 就变成一个以 EXPLAIN 开始的 SQL 语句;如果E 设置为 2,S 就变成一个以 EXPLAIN QUERY PLAN 开始的 SQL 语句。

    查询优化

    查询优化器增强包括:

    • LEFT JOIN 强度削减优化扩展至 RIGHT JOIN 以及 FULL JOIN,并且重命名为 OUTER JOIN 强度消减优化。
    • 改进了 OUTER JOIN 强度消减优化使用的理论证明器,减少了假阴性的情况。

    Decimal 扩展

    新版本增强了与 decimal 扩展相关的内容:

    • 新增函数 decimal_pow2(N),返回 2.0 的 N 次方,N 为 -2000 到 +2000 之间的整数;
    • 新增函数 decimal_exp(X),以科学计数法形式(e+NN)返回 X 的十进制数字;
    • 对于浮点数 X,decimal(X) 函数将会返回完全扩展的精确数字。

    例如:

    select decimal_pow2(10);
    +1.024e+03
    
    select decimal_exp(12.3);
    +1.2300000000000000710542735760100185871124267578125e+01
    
    select decimal(12.3);
    12.300000000000000710542735760100185871124267578125
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    JSON 性能

    某些情况下,对于大型 JSON 字符串的处理性能获得翻倍提升。

  • 相关阅读:
    初等数论——素数,逆元,EXGCD有关
    C51单片机使用1-工程创建和Led闪烁灯
    如何理解CRC循环冗余校验——图解CRC算法模型和C语言实现
    Python协程(asyncio)(二)高级开发
    Android问题解决
    安卓系统精简与优化
    pytorch faster_rcnn转为onnx格式
    C语言:链表
    三川智控定时控制开关灯
    Java:Java和Python,哪个更适合业务应用程序开发?
  • 原文地址:https://blog.csdn.net/horses/article/details/132535127