当前位置: 首页 > 编程日记 > 正文

【数据库】sqlite中的限制:数据库大小、表数、列数、行数、参数个数、连接数等

目录

        • 一、参考网址
        • 二、详解
          • 1、查看、设置sqlite限制命令.limit
          • 2、SQLite中的限制汇总
            • 1)字符串或BLOB的最大长度
            • 2)最大列数
            • 3)SQL语句的最大长度
            • 4)联接中的最大表数
            • 5)表达式树的最大深度
            • 6)函数的最大参数个数
            • 7)复合SELECT语句中的最大项数
            • 8)LIKE或GLOB模式的最大长度
            • 9)单个SQL语句中的最大占位符个数
            • 10)触发递归的最大深度
            • 11)数据库关联的最大数
            • 12)数据库文件中的最大页数
            • 13)表中的最大行数
            • 14)数据库大小限制
            • 15)表个数限制
          • 3、运行时限制类别

一、参考网址

SQLite中的限制(官网):https://sqlite.org/limits.html
运行时限制类别(官网):https://sqlite.org/c3ref/c_limit_attached.html#sqlitelimitcolumn

二、详解

1、查看、设置sqlite限制命令.limit
sqlite> .limit	// 显示或设置数据库限制信息:SQLITE_LIMITlength 1000000000	// 字符串或BLOB的最大长度10亿,一行的最大长度sql_length 1000000000	// sql语句最大长度column 2000	// 列数,可以在编译时才可以将最大列出改为32767expr_depth 1000	// 表达式树的最大深度,SQLite将表达式解析到树中进行处理。compound_select 500	// 复合SELECT语句中的最大术语数vdbe_op 25000	// 虚拟机程序中用于实现SQL语句的最大指令数function_arg 127	// 一个函数的最大参数个数attached 10		// ATTACH语句,附加数据库最大值为125like_pattern_length 50000	// LIKE模式匹配算法或GLOB模式的最大长度variable_number 250000	// 任何参数的索引号trigger_depth 1000	// 触发递归的最大深度worker_threads 0		// 可以启动的辅助工作线程的最大数量
2、SQLite中的限制汇总
1)字符串或BLOB的最大长度

注:BLOB是sqlite的一种类型,用于存储二进制。
限制SQLite中字符串、BLOB类型值、数据库一行的最大字节数,默认值为10亿,最大为2147483647;
在编译时,通过SQLITE_MAX_LENGTH来设置;

-DSQLITE_MAX_LENGTH = 123456789

在运行时,通过sqlite3_limit(db, SQLITE_LIMIT_LENGTH, size)来降低该值;

官方建议:最好将最大字符串长度和blob长度减小到几百万。
在SQLite的INSERT和SELECT处理的一部分期间,数据库中每一行的全部内容被编码为单个BLOB。因此,SQLITE_MAX_LENGTH参数还确定一行中的最大字节数。

2)最大列数

最大列数用于限制一下项的上限:

表中的列数
索引中的列数
视图中的列数
UPDATE语句的SET子句中的术语数
SELECT语句的结果集中的列数
GROUP BY或ORDER BY子句中的术语数
INSERT语句中的值数

默认值为2000,最大为32767;
在编译时,通过SQLITE_MAX_COLUMN来设置,
在运行时,通过sqlite3_limit(db, SQLITE_LIMIT_COLUMN,size)来降低最大列数。

3)SQL语句的最大长度

对SQL语句的最大字节数的限制,默认值为1000000,最大为SQLITE_MAX_LENGTH和1073741824中较小的一个。
在编译时,通过SQLITE_MAX_SQL_LENGTH来设置;
在运行时,通过sqlite3_limit(db, SQLITE_LIMIT_SQL_LENGTH, size)来降低该值。

4)联接中的最大表数

SQLite不支持包含超过64个表的联接。不可更改

5)表达式树的最大深度

限制SQL语句表达式的复杂程度;
编译时通过SQLITE_MAX_EXPR_DEPTH参数设置,默认是1000;
如果SQLITE_MAX_EXPR_DEPTH为正,可以在运行时通过sqlite3_limit(db,SQLITE_LIMIT_EXPR_DEPTH,size)来降低
如果SQLITE_MAX_EXPR_DEPTH为0,则不受限制,上面的接口无效。

6)函数的最大参数个数

限制函数的参数个数,默认值是100,最大为127;
在编译时,通过SQLITE_MAX_FUNCTION_ARG来设置最大值;
在运行时,通过sqlite3_limit(db,SQLITE_LIMIT_FUNCTION_ARG,size)来降低该值。

7)复合SELECT语句中的最大项数

复合SELECT语句是通过运算符UNION,UNION ALL,EXCEPT或INTERSECT连接的两个或多个SELECT语句。每个单独的SELECT语句称为“项”。
默认值为500;官方不建议再增大;
在编译时,通过SQLITE_MAX_COMPOUND_SELECT来设置最大值;
在运行时,通过 qlite3_limit(db,SQLITE_LIMIT_COMPOUND_SELECT,size)来降低该值。

8)LIKE或GLOB模式的最大长度

LIKE、GLOB运算符:模式匹配比较,类似正则表达式;
限制LIKE或GLOB模式的表达式的字符长度;默认值为50000,官方不建议再增大;
在编译时,通过SQLITE_MAX_LIKE_PATTERN_LENGTH来设置最大值;
在运行时,通过sqlite3_limit(db,SQLITE_LIMIT_LIKE_PATTERN_LENGTH,size)来降低该值。

9)单个SQL语句中的最大占位符个数

限制C或C++ SQL接口中使用的占位符的个数;默认为999,最大值10亿;
在编译时,通过SQLITE_MAX_VARIABLE_NUMBER来设置最大值;
在运行时,通过sqlite3_limit(db,SQLITE_LIMIT_VARIABLE_NUMBER,size)来降低该值。

10)触发递归的最大深度

SQLite 触发器(Trigger)是数据库的回调函数,它会在指定的数据库事件发生时自动执行/调用。
限制回调函数递归的深度。
默认值是1000.;
在编译时,通过SQLITE_MAX_TRIGGER_DEPTH来设置最大值;
在运行时,无法设置;

11)数据库关联的最大数

使用ATTACH可以将多个数据库关联到一起,这样在操作时,就像操作一个数据库。
限制关联数据库的个数,默认值10,最大125;
在编译时,通过SQLITE_MAX_ATTACHED来设置最大值;
在运行时,通过sqlite3_limit(db,SQLITE_LIMIT_ATTACHED,size)来降低该值。

12)数据库文件中的最大页数

防止单个数据库文件过大;数据库文件大小由页数和单个页大小决定;
默认值为1073741823,最大2147483646
在编译时,通过SQLITE_MAX_PAGE_COUNT来设置;
在运行时,通过PRAGMA schema.max_page_count来查询和设置该值;
在插入新数据时,页数将要超过该值,会返回SQLITE_FULL。
如果页数最大为2147483646,页大小为65536时,数据库大小约为140 TB。

13)表中的最大行数

表中的理论最大行数为2^ 64(18446744073709551616或大约1.8e+19)。由于将首先达到140 TB的最大数据库大小,因此无法达到此限制。一个140 TB的数据库最多可以容纳大约1e+13行。
无法改变该值。

14)数据库大小限制

页数最大为2147483646,页大小为65536时,数据库大小约为140 TB

15)表个数限制

保存每个表的描述信息需要一页,因此该表的数量不会超过页数。
初始化数据库时,需要扫描所有表的描述信息、并保存在内存中。因此数据库连接启动时间和初始内存使用量和表的数量成正比。

3、运行时限制类别
#define SQLITE_LIMIT_LENGTH                    0
#define SQLITE_LIMIT_SQL_LENGTH                1
#define SQLITE_LIMIT_COLUMN                    2
#define SQLITE_LIMIT_EXPR_DEPTH                3
#define SQLITE_LIMIT_COMPOUND_SELECT           4
#define SQLITE_LIMIT_VDBE_OP                   5
#define SQLITE_LIMIT_FUNCTION_ARG              6
#define SQLITE_LIMIT_ATTACHED                  7
#define SQLITE_LIMIT_LIKE_PATTERN_LENGTH       8
#define SQLITE_LIMIT_VARIABLE_NUMBER           9
#define SQLITE_LIMIT_TRIGGER_DEPTH            10
#define SQLITE_LIMIT_WORKER_THREADS           11

这些常量定义了各种性能限制,可以在运行时使用 sqlite3_limit 降低这些限制

int sqlite3_limit(sqlite3*, int id, int newVal);

id取值如下:
SQLITE_LIMIT_LENGTH:任何字符串或BLOB或表行的最大大小,以字节为单位。

SQLITE_LIMIT_SQL_LENGTH:SQL语句的最大长度,以字节为单位。

SQLITE_LIMIT_COLUMN:表定义或SELECT结果集中的最大列数,或索引或ORDER BY或GROUP BY子句中的最大列数。

SQLITE_LIMIT_EXPR_DEPTH:任何表达式上分析树的最大深度。

SQLITE_LIMIT_COMPOUND_SELECT:复合SELECT语句中的最大术语数。

SQLITE_LIMIT_VDBE_OP:虚拟机程序中用于实现SQL语句的最大指令数。如果sqlite3_prepare_v2()或等效方法试图在单个准备好的语句中为多个操作码分配空间,则将返回SQLITE_NOMEM错误。

SQLITE_LIMIT_FUNCTION_ARG:一个函数的最大参数个数。

SQLITE_LIMIT_ATTACHED:附加数据库的最大数量。

SQLITE_LIMIT_LIKE_PATTERN_LENGTH:LIKE或 GLOB运算符的pattern参数的最大长度。

SQLITE_LIMIT_VARIABLE_NUMBER:SQL语句中任何参数的最大索引号。

SQLITE_LIMIT_TRIGGER_DEPTH:触发器的最大递归深度。

SQLITE_LIMIT_WORKER_THREADS:一个准备好的语句可以启动的辅助工作线程的最大数量 。

相关文章:

flutter中的生命周期

前言 和其他的视图框架比如android的Activity一样,flutter中的视图Widget也存在生命周期,生命周期的回调函数提现在了State上面。理解flutter的生命周期,对我们写出一个合理的控件至关重要。组件State的生命周期整理如下图所示: 大…

小鱼易连获腾讯数亿C轮投资,云视频布局产业互联网

4 月 18 日,小鱼易连在北京举行 “鱼腾视界 产业互联” 战略合作暨融资发布会上,正式宣布获得 C 轮融资,由腾讯领投。融得的资金将全面用于小鱼易连云视频系统在产业互联网领域的落地,打通企业、政府、个人三者之间的柔性生态全产…

异步IO一定更好吗?

http://cnodejs.org/blog/?p1015续:异步IO一定更好吗?我之前的一篇文章《异步IO一定更好吗?》中举了一个很变态的例子,用以说明在单碟机械式硬盘上异步IO反而可能降低性能的问题,大家的讨论很热烈。前天的NodeParty杭…

谈谈Python那些不为人知的冷知识(二)

本文转载自Python的编程时光(ID:Python-Time)小明在日常Code中遇到一些好玩,冷门的事情,通常都会记录下来。从上一篇的分享来看,仍然有不少 Pythoner 对这些冷知识存在盲区,所以今天迎来第二篇。如果上篇你…

前端每日实战:45# 视频演示如何用纯 CSS 创作一个菱形 loader 动画

效果预览 按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/eKzjqK 可交互视频教程 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。 请用 chrome, safari, edge 打开观看。…

【数据库】SQLite和MySQL之间的对比和选择

目录1、各自特定2、使用场景3、选择哪个1、各自特定 SQLite :独立、简单(零配置);适用于为单个应用程序和设备提供本地数据存储。 MySQL:可伸缩、高并发性;适用于客户端/服务器模式企业数据的共享数据存储…

MySql中管理百万级要注意些什么东西(转载)

一、我们可以且应该优化什么? 硬件 操作系统/软件库 SQL服务器(设置和查询) 应 用编程接口(API) 应用程序 二、优化硬件 如果你需要庞大的数据库表 (>2G),你应该考虑使用64位的硬件结构,像Alpha、Sparc或即将推出的IA64。因为MySQL内部使用…

【数据库】sqlite3数据库备份、导出方法汇总

【数据库】sqlite3常用命令及SQL语句 目录1、直接拷贝数据库2、使用.backup .clone1)交互式2)脚本3、导出到csv文件中(其它格式类似)1)交互式2)脚本3)导出成其它格式汇总a> .mode asciib>…

高通与苹果宣布“复合”,英特尔黯然退场 | 极客头条

作者 | 郭芮转载自公众号CSDN(ID:CSDNnews)为期两年的苹果高通“诉讼之争”经历了各种推波助澜愈演愈烈,俨然到了最为关键的白热化阶段,没成想,在刚刚正式进入美国司法庭审环节的两天后却被强势叫停了!4 月…

MQTT 协议 Client ID 长度不能超过23个字符

今天遇到一个MQTT的问题,MqttException: MQIsdp ClientId > 23 bytes ClientId的长度大于23时,无法链接MQTT服务器。 经过查看协议发现:客户端标识符(Client ID)是介于1和23个字符长度,客户端到服务器的唯一标识。它必须在搜有客户端连接到…

【数据库】适用于SQLite的SQL语句(一)

目录一、统计函数二、表TABLE1、创建表CREATE TABLE2、更改表ALTER TABLE3、删除表DROP TABLE三、分析表ANALYZE四、附加数据库 ATTACH DATABASE五、事务六、核心函数七、索引INDEX1、创建索引:CREATE INDEX2、查看索引:3、使用索引 INDEXED BY4、删除索…

谷歌大神Jeff Dean点赞网红博士论文:改进分布式共识机制 | 技术头条

作者 | Heidi Howard编译 | 刘静本文转载自公众号图灵TOPIA(ID:turingtopia)本文作者Heidi Howard,是剑桥大学计算机科学与技术系系统研究小组的分布式系统研究员。Heidi的研究领域一直围绕分布式系统中的一致性,容错性和性能并且…

使用Nginx做前端服务器时让Apache得到真实IP的方法

一:nginx.conf proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 其实这个proxy.conf里面默认都有,在nginx.conf使用include proxy.conf就可以 二:apa…

Hadoop生态圈-hive五种数据格式比较

Hadoop生态圈-hive五种数据格式比较 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任。

华为巨资收购为云计算趟平道路?

华为巨资收购为云计算趟平道路&#xff1f;<?xml:namespace prefix o ns "urn:schemas-microsoft-com:office:office" />文 小刀马众所周知&#xff0c;华为在全球的技术能力和市场地位也是有目共睹的&#xff0c;这是华为多少年兢兢业业守成的一种回报。更…

【数据库】适用于SQLite的SQL语句(二)

目录九、视图VIEW1、创建视图2、删除视图十、虚拟表1、创建虚拟表2、删除虚拟表十一、时间和日期的函数十二、分析和故障排除十三、SQL语句中的表达式1、运算符2、字面值3、参数十四、插入 INSERT十五、SQLite关键字十六、解决冲突 ON CONFLICT九、视图VIEW 视图是基于真实数据…

从对ML一窍不通到斩获AT等special offer,拿下大厂算法岗就靠它了

整理 | 一一出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;2019 年春招就要过去&#xff0c;秋招也就不远了。对于很多计算机专业的毕业生来说&#xff0c;大部分都还处于迷茫期&#xff0c;由于大学时的大部分时间都可能在划水&#xff0c;导致不知道现在如何准备就…

WWDC2018总结

本人的第一篇文章&#xff08;现在写文章是为了提升自己的语句表达能力&#xff09; 欢迎大家观看本文章&#xff0c;是略微总结一下WWDC2018发布的iOS12的新东西 iOS12略微总结&#xff08;持续更新。。。&#xff09; iOS12 变化 iOS 12新功能汇总&#xff08;后面希望可以上…

make报错:/usr/bin/ld: cannot find -lXXX

在编译php时报错如下&#xff1a; # make 。。。 /usr/bin/ld: cannot find -lltdl collect2: ld returned 1 exit status make: *** [libphp5.la] Error 1 问题原因&#xff1a; 该问题一般是由于ld在进行库的连接时找不到库文件所致&#xff1a; 解决方案&#xff1a; 出现该…

for死循环、怪异字符串、两次return……Python冷知识(三)

本文转载自Python编程时光&#xff08;ID:Python-Time&#xff09;冷知识系列&#xff0c;已经更新至第三篇。前两篇传送门小明给你准备好了&#xff0c;还没阅读的可以学习一下。谈谈 Python 那些不为人知的冷知识&#xff08;一&#xff09;谈谈 Python 那些不为人知的冷知识…

snmpd 子代理模式编译测试

1、参考链接 1&#xff09;Net-snmp添加子代理示例https://blog.csdn.net/eyf0917/article/details/395466512、操作步骤1&#xff09;网络拷贝下面的文件http://www.net-snmp.org/tutorial/tutorial-5/toolkit/mib_module/NET-SNMP-TUTORIAL-MIB.txthttp://www.net-snmp.org/t…

【数据库】适用于SQLite的SQL语句(三)

目录十七、重新引索REINDEX十八、查询SELECT1、简单查询2、复合查询十九、更新UPDATE二十、公用表表达式&#xff08;CTE&#xff09;WITH1、普通表达式2、递归表达式二十三、VACUUM二十四、UPSERT十七、重新引索REINDEX REINDEX命令用于从头开始删除和重新创建索引。 十八、…

算法系列15天速成——第二天 七大经典排序【中】

首先感谢朋友们对第一篇文章的鼎力支持&#xff0c;感动中....... 今天说的是选择排序&#xff0c;包括“直接选择排序”和“堆排序”。 话说上次“冒泡排序”被快排虐了&#xff0c;而且“快排”赢得了内库的重用&#xff0c;众兄弟自然眼红&#xff0c;非要找快排一比高下。…

如何构建优质的推荐系统服务?| 技术头条

作者丨gongyouliu来源 | 大数据与人工智能&#xff08;ID:ai-big-data&#xff09;任何一个优质的软件服务都必须考虑高性能、高可用(HighAvailability)、可伸缩、可拓展、安全性等5大核心要素&#xff0c;推荐系统也不例外。所以&#xff0c;我们会围绕这5个点来说明&#xff…

DispatcherServlet之HandlerAdapter的handle

2019独角兽企业重金招聘Python工程师标准>>> 注&#xff1a;SpringFramework的版本是4.3.x。 1.DispatcherServlet的doService方法时序图 图1 DispatcherServlet的doService方法时序图 2.AnnotationMethodHandlerAdapter的handle方法时序图 图2的原图在Gith…

【C++】C++11 STL算法(九):番外篇

1、如果获取指针或迭代器指向的类型 详见&#xff1a;C 11&#xff1a;如何获取一个指针或迭代器指向的类型&#xff1f; decltype(*std::declval<Pointer>())decltype&#xff1a;c11关键字&#xff0c;类型推导。详见&#xff1a;【C】C11新增关键字详解 std::declva…

IBM Tivoli Netview在企业网络管理中的实践(附视频)

今天我为大家介绍的一款高端网管软件名叫IBM Tivoli NetView&#xff0c;他主要关注是IBM整理解决方案的用户&#xff0c;分为Unix平台和Windwos平台两种&#xff0c;这里视频演示的是基于Windows 2003 server下的IBM Tivoli NetView 6.1在企业中的部署应用&#xff0c;可以为大…

【C++】C++11 STL算法(十):使用STL实现排序算法

一、快速排序 1、适用于c11版本 template <class ForwardIt> void quicksort(ForwardIt first, ForwardIt last) {if(first last) return;auto pivot *std::next(first, std::distance(first,last)/2);ForwardIt middle1 std::partition(first, last, [pivot](con…

“你行你上”:有本事跟OpenAI Five打一把DOTA?| 极客头条

整理 | 一一出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;你们不是嫌弃世界冠军 OG 团队实力太水吗&#xff1f;“你行你上”的机会来了。4 月 14 日凌晨&#xff0c;OpenAI Five 以 2:0 击败了 DOTA 世界冠军团队 OG 引发热议。比赛当天&#xff0c;OpenAI 也宣布…

Java学习笔记二十五:Java面向对象的三大特性之多态

Java面向对象的三大特性之多态 一&#xff1a;什么是多态&#xff1b; 多态是同一个行为具有多个不同表现形式或形态的能力. 多态就是同一个接口&#xff0c;使用不同的实例而执行不同操作. 多态性是对象多种表现形式的体现。 现实中&#xff0c;比如我们按下 F1 键这个动作&am…