SQLite Autoincrement特性

摘要

  1. AUTOINCREMENT会使用额外的CPU、内存和磁盘空间,如不是特别需要尽量不要使用。
  2. 类型为INTEGER PRIMARY KEY的列会被作为rowid(WITHOUT ROWID表除外),并且是一个8字节有符号整数。
  3. 执行INSERT操作时如果未提供rowid,会自动分配一个未使用的整数,通常是大于当前使用的最大rowid,不论该列是否赋予了AUTOINCREMENT特性。
  4. AUTOINCREMENT关键字出现在INTEGER PRIMARY KEY之后,该特性会改变表的rowid分配算法,不会重复使用之前删掉的rowid值。

背景

rowid会被分配一个表内唯一有符号整数(WITHOUT ROWID表除外)。
通过 “rowid”,“rowid”,"oid"可以访问rowid列,或者使用被作为rowid列的INTEGER列名称。
插入新记录时,即可以明确指定一个rowid值,也可以不提供,系统分自动分配。

CREATE TABLE test1(a INT, b TEXT);
INSERT INTO test1(rowid, a, b) VALUES(123, 5, 'hello');

如果在插入记录时未指定rowid或指定了一个NULL值,系统会自动分配一个rowid。默认是分配一个比最后一次插入时分配的rowid大的值,从1开始。如果达到最大值(9223372036854775807),则会扫描表并使用一个未使用的rowid。如果未找到可用值则报错SQLITE_FULL。如果未显式插入一个负的rowid则自动分配的rowid永远是正值。

常规算法是只要未达到最大值则单调递增rowid。如果显式指定了最大值,下次分配时将使用之前删除的值,在这种情况下分配的rowid不会是严格递增的。

AUTOINCREMENT关键字

带有AUTOINCREMENT特性的INTEGER PRIMARY KEY列,其自增算法会与rowid的分配算法稍有不同。仍然从1开始分配,但如果达到孙最大值,下次插入时会报错SQLITE_FULL,而不会重复使用之前删除的值,除非上一个分配id的事务操作被回滚,这个值会被使用到下一次插入操作。

SQLite内部使用一个名称为sqlite_sequence的内部表存储自增字段的值,该表会在创建一个带有AUTOINCREMENT特性的表的时候自动创建。该表可以通过UPDATE、INSERT和DELETE语句直接修改,但不建议去操作该表。

单调递增并不一定意味着下次分配的值一定是增加1。例如在一次插入失败时,后续插入操作可能不会再使用那个插入失败时分配的id。简单概括就是不能假定该值一定比上一个分配的值大1。

在WITHOUT ROWID表中,或非INTEGER PRIMARY KEY列上面不允许使用AUTOINCREMENT特性。

原文链接:https://www.sqlite.org/autoinc.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/101064.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【AN-Animate教程——熟悉工作区】

【AN-Animate教程——熟悉工作区】 初始页面创建舞台主舞台界面其他常用板块 本篇内容:Animate用途 重点内容:熟悉工作区,以及基本操作 工 具:Adobe Animate 2022 初始页面 在初始页面当中,我们可以看到一个忍者和一个…

Mainflux IoT:Go语言轻量级开源物联网平台,支持HTTP、MQTT、WebSocket、CoAP协议

Mainflux是一个由法国的创业公司开发并维护的安全、可扩展的开源物联网平台,使用 Go语言开发、采用微服务的框架。Mainflux支持多种接入设备,包括设备、用户、APP;支持多种协议,包括HTTP、MQTT、WebSocket、CoAP,并支持…

Redis根据中心点坐标和半径筛选符合的数据

目录 1.启动Redis​编辑 2.导入maven依赖 3.添加redis配置 4.编写RedisService 5.使用 6.验证 1.启动Redis 2.导入maven依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifac…

uniapp搭建项目

使用Vue3/Vite版 创建以 javascript 开发的工程&#xff08;如命令行创建失败&#xff0c;请直接访问 gitee 下载模板&#xff09; npx degit dcloudio/uni-preset-vue#vite my-vue3-project复制代码 npx degit dcloudio/uni-preset-vue#vite-alpha my-vue3-project复制代码创…

pnpm、npm、yarn 包管理工具『优劣对比』及『环境迁移』

前言 博主在开发前端网站的时候&#xff0c;发现随着开发的项目的逐渐增多&#xff0c;安装的依赖包越来越臃肿&#xff0c;依赖包的安装速度也是非常越来越慢&#xff0c;多项目开发管理也是比较麻烦。之前我就了解过 pnpm&#xff0c;但是当时担心更换包管理环境可能会出现的…

[modern c++] 函数式编程与 std::ref

参考&#xff1a; std::ref, std::cref - cppreference.comhttps://en.cppreference.com/w/cpp/utility/functional/ref 正文&#xff1a; 如果不涉及函数式编程&#xff0c;那么基本上不需要使用到 std::ref &#xff0c; 这个功能式是用来解决函数式编程时入参只能进行值传…

openlayers图层数据覆盖

openlayers图层数据覆盖 openlayer 有两个图层A和B 图层A 覆盖 图层B 在 OpenLayers 中&#xff0c;可以通过添加不同的图层来实现图层的覆盖效果。要使图层A覆盖图层B&#xff0c;你可以按照以下步骤进行操作&#xff1a; 1 创建地图容器&#xff1a; var map new ol.Map…

【思维构造】Dominant Character—CF1605C

Dominant Character—CF1605C 思路 若字符串中存在相邻的 a 字符&#xff0c;即存在 aa 子串。输出 2 2 2。若字符串中不存在相邻的 a 字符。那么满足条件的子串的格式一定是 a xx a ... a xx a&#xff0c;其中 xx 代表由 b 和 c 组成的字符串。那么显然可以对 a 的数…

什么是广电入库

什么是广电入库 入库&#xff0c;就意味着该节目在广播电视媒体机构可随时随地被调用&#xff0c;可任意安排播出时间和播出频率。入库的节目可实现一次制作&#xff0c;无限次使用&#xff0c;大大提高节目制作效率。同时&#xff0c;入库的节目因为具有统一的标准和规范&…

使用poi-tl循环导出word报表

先看模板和导出的效果 模板 效果 根据模板循环生成表格&#xff0c;每个表格再循环填充数据&#xff0c;也就是两层循环&#xff0c;第一层循环是学生学期信息&#xff0c;第二层循环是学生的成绩数据。 第一个循环 {{?listTable}} {{/}}第二个循环 {{reportList}} 表格…

Python 何时传的是值,何时传的是引用?

在 Python 中&#xff0c;参数的传递方式可以是传值&#xff08;pass by value&#xff09;或传引用&#xff08;pass by reference&#xff09;。然而&#xff0c;实际上 Python 中的参数传递方式是通过对象的引用进行传递。简单来说&#xff0c;当传递不可变对象时&#xff0…

KWin、libdrm、DRM从上到下全过程 —— drmModeAddFBxxx(4)

接前一篇文章:KWin、libdrm、DRM从上到下全过程 —— drmModeAddFBxxx(3) 上一回讲解了drm_mode_addfb2函数中的第一步暨第一个函数drm_core_check_feature。本回继续对于drm_mode_addfb2函数往下进行解析。为了便于理解,再次贴出其代码,在drivers/gpu/drm/drm_framebuffe…

电脑图片jpeg怎么转jpg格式?jpeg和jpg的转换方法

很多平台对上传的图片格式都有严格的要求&#xff0c;当我们遇到图片格式不对的时候&#xff0c;就需要改图片格式了&#xff0c;下面以jpeg转jpg&#xff08;在线图片格式转换器&#xff08;jpg、png、gif、webp、bmp、tiff&#xff09;-压缩图&#xff09;为例子&#xff0c;…

SpringBoot项目整合

一、创建项目 IDEA中采用spring initialzer...创建&#xff0c;jdk选择8&#xff0c;maven,jar。。。springboot版本2.5.0&#xff08;稳定&#xff09; 项目依赖&#xff1a; 二、项目结构&#xff1a; 原始pom.xml文件 <?xml version"1.0" encoding"UT…

Android网络监听

1.通过注册BroadCastReceiver进行网络监听。 1) 添加网络权限 <uses-permission android:name"android.permission.INTERNET"/><uses-permission android:name"android.permission.ACCESS_NETWORK_STATE" /> 2&#xff09;定义BroadCastRe…

tcpdump(五)命令行参数讲解(四)

一 案例讲解 tcpdump官方参考文档 最全的tcpdump手册 强调&#xff1a; -nn 选项一般是must 必选 ① 现场分析并保留现场信息 tcpdump -l | tee dat 使用tee来把tcpdump的输出同时放到文件dat和标准输出中场景&#xff1a; 自己现场分析同时把现场信息保留下来 ② …

朋友圈一键转发(可修改文案),无需多个账号复制粘贴

相信很多人手上都有不止一个微信&#xff0c;每次发个朋友圈都要在多个账号切换&#xff0c;重复发送&#xff0c;好不麻烦。而一些朋友想要一键跟随转发朋友圈&#xff0c;却总是需要一个个复制粘贴&#xff0c;麻烦而且容易漏发。 那实现朋友圈一键跟随转发&#xff0c;无需多…

wifi管理软件 WiFi Signal mac中文介绍

WiFi Signal mac是一款WiFi信号强度监测工具&#xff0c;它可以帮助用户实时监测WiFi信号的强度、频率、噪声等信息&#xff0c;并提供详细的图表和统计数据。 WiFi Signal可以自动扫描附近的WiFi网络&#xff0c;并显示它们的信号强度和频率。用户可以通过WiFi Signal来找到最…

ES知识点全面整理

● 我们从很多年前就知道 ES6, 也就是官方发布的 ES2015 ● 从 2015 年开始, 官方觉得大家命名太乱了, 所以决定以年份命名 ● 但是大家还是习惯了叫做 ES6, 不过这不重要 ● 重要的是, ES6 关注的人非常多, 大家也会主动去关注 ● 但是从 2016 年以后, 每年官方都会出现新…

lua 如何在嵌入式Linux中与c语言结合

在嵌入式Linux中&#xff0c;可以使用Lua语言来扩展C语言应用程序的功能。具体而言&#xff0c;Lua可以被嵌入到C语言应用程序中&#xff0c;以便通过Lua脚本文件调用C语言函数或库。下面是一些步骤&#xff1a; 在嵌入式Linux中安装Lua库 可以使用apt-get、yum等命令从Linux…