亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

SQLite3中自增主鍵相關知識總結

瀏覽:258日期:2023-04-05 14:56:07

一、SQLite清空表并將自增列歸零

SQL標準中有TRUNCATE TABLE語句,用來清空表的所有內容。
但SQLite不支持這個語句。在SQLite中直接使用 DELETE FROM TableName 就可以了。
對于大多數DBMS來說,用DELETE不如用TRUNCATE 速度快,因為TRUNCATE 不用訪問整個表,不用記錄數據的變動。

SQLite雖然不支持TRUNCATE,但它對DELETE做了優化:
通常在清空表的時候,還需要把自增列歸零。在SQLite中定義自增列的方法如下:
復制代碼 代碼如下:CREATE TABLE TableName ( id INTEGER PRIMARY KEY AUTOINCREMENT, name varchar, type Integer );

當SQLite數據庫中包含自增列時,會自動建立一個名為 sqlite_sequence 的表。
這個表包含兩個列:name和seq。name記錄自增列所在的表,seq記錄當前序號(下一條記錄的編號就是當前序號加1)。
如果想把某個自增列的序號歸零,只需要修改 sqlite_sequence表就可以了。
復制代碼 代碼如下:UPDATE sqlite_sequence SET seq = 0 WHERE name="TableName";

也可以直接把該記錄刪掉:      
復制代碼 代碼如下:DELETE FROM sqlite_sequence WHERE name="TableName";
要想將所有表的自增列都歸零,直接清空sqlite_sequence表就可以了:
復制代碼 代碼如下:DELETE FROM sqlite_sequence;

二、Sqlite中INTEGER PRIMARY KEY AUTOINCREMENT和rowid的使用

在用sqlite設計表時,突然想到一個問題,就是我設計的表中,每個表都有一個自己的整形id值作為主鍵,
其實可以不指定這么一個id值,sqlite內部本來就會為每個表加上一個 rowid,這個rowid可以當成一個隱含的字段使用,

為什么不直接使用這個內部的rowid作為每個表的id主鍵呢。
使用自增長字段為主鍵有不少問題,比如維護或是在大型分布應用中主鍵沖突的解決等。
在一些大型分布應用中主鍵一般選用guid,這可以有效的避免主鍵沖突,減少對主鍵維護的工程。
當然,對于中小型的應用,自增長字段的好處更多一些,簡單、快速。

Sqlite中,一個自增長字段定義為 INTEGER PRIMARY KEY AUTOINCREMENT
那么在插入一個新數據時,只需要將這個字段的值指定為NULL,即可由引擎自動設定其值,
引擎會設定為最大的rowid+1 當然,也可以設置為非NULL的數字來自己指定這個值,但這樣就必須自己小心,不要引起沖突。

rowid的新值會這個最大數之前隨機找一個沒被使用了的值。所以在rowid達到最大值前,rowid的值是嚴格單調增加的。
INTEGER PRIMARY KEY AUTOINCREMENT 自增長字段的算法與rowid稍微有些不同。
第一,在達到最大值后,rowid會找已被刪除的字段對應的rowid作為新值,而自增長字段則會丟出一個SQLITE_FULL的錯誤。
第二,自增長字段在增加新值時,是找一個從沒被使用過的rowid作為新值,而rowid則是找最大已存在的rowid+1。

這里對應用的影響會比較大,尤其是一些對id值有依賴的元記錄,只適合使用自增長字段而不能用rowid。
比如,我們設計一個元記錄表:
復制代碼 代碼如下:Create table meta_struct(id INTEGER PRIMARY KEY AUTOINCREMENT, name varchar, type Integer);
然后,定義一個一級表,來描述其它表的結構:
復制代碼 代碼如下:Create table meta_table(tableid INTEGER, table_field integer)

最后,我們的應用可以根據這個一級表來產生實際使用的二級表。
這樣為保證兼容性meta_struct中的id必須是唯一的,如果有字段被刪除,也不能重復使用這個字段的id值,不然,在數據庫合并時,
一級表和二級表就會混亂。所以meta_struct表中的主鍵只能使用自增長字段,而不能用rowid。

第三,使用自增長字段,引擎會自動產生一個sqlite_sequence表,用于記錄每個表的自增長字段的已使用的最大值,用戶可以看到,
并可以用使用Update、Delete和Insert操作,但不建議這么使用,這會讓引擎混亂。如果使用rowid,也會有這么一個內部表,用戶可以維護rowid值,但看不到。

標簽: SQLite
相關文章:
主站蜘蛛池模板: 中文乱码一二三四有限公司 | 国产一久久香蕉国产线看观看 | 免费人成黄页在线观看69 | 国产爆操| 91国视频在线 | 中国麻豆 | 妞干网免费在线 | 成人一区二区丝袜美腿 | 国产精品第一 | 欧美国产日韩做一线 | 亚洲一区二区精品 | 老司机深夜福利影院 | 一级一级一级毛片免费毛片 | 亚洲xxxx视频| 成人黄色一级片 | 拍拍拍又黄又爽无挡视频免费 | 欧美黑人特大巨黑吊 | 国产丝袜制服 | 日韩欧美一区二区三区视频 | 日韩精品另类天天更新影院 | 中文字幕亚洲日本岛国片 | 国产亚洲精品久久久久91网站 | 成人性爱视频在线观看 | 性激烈的欧美三级高清视频 | 鲁大师在线观看免费播放 | 亚洲va老文色欧美黄大片人人 | 日韩在线你懂的 | www视频在线观看 | 国产欧美专区在线观看 | 日日夜夜操操操 | 日韩免费a级在线观看 | 亚洲伦理一区二区 | 久视频在线| 日韩免费黄色片 | 国内视频拍拍视频在线观看 | 秀人网福利视频在线观看 | 久久夜色撩人精品国产 | 日韩高清在线免费观看 | 又黄又爽的成人免费视频播放 | 亚欧成人毛片一区二区三区四区 | 看最刺激的欧美毛片 |