SQLite自增ID自段
使用方法為 INTEGER PRIMARY KEY AUTOINCREMENT
如:
CREATE TABLE 21andy ( id INTEGER PRIMARY KEY AUTOINCREMENT, 21andy VARCHAR(100) NOT NULL, date DATE );
注意是AUTOINCREMENT, 和MySQL的寫法不一樣
SQLite清空表
SQLite沒有TRUNCATE清空表指令,是以隻能這樣
DELETE FROM 21andy;
SQLite 删除記錄後, 自增ID置0
隻能這樣
DELETE FROM sqlite_sequence;
另外, 這個sqlite_sequence可以CRUD
SQLite 删除記錄後, 不會釋放空間
必須像這樣
VACUUM
SQLite 分頁查詢
有兩種寫法:
Select * From Account Limit 9 Offset 10;
SELECT * FROM Account LIMIT 10, 9
他們兩個的效果都是一樣的,其中第一種寫法比較清晰明了,即跳過10行,讀取其後的9行資料.
SQLite批量插入資料
很不幸的事情是貌似SQLite隻能一條一條的執行插入,但是這是非常非常慢的行為,執行一條就是執行一次寫入磁盤的操作,這實在是太可怕了.在SQLite裡面執行批量插入,隻能将插入操作放入到事務當中去.示例如下:
BEGIN;
CREATE TABLE t2(a INTEGER, b INTEGER, c VARCHAR(100));
INSERT INTO t2 VALUES(1,59672,'fifty nine thousand six hundred seventy two');
INSERT INTO t2 VALUES(24999,89569,'eighty nine thousand five hundred sixty nine');
INSERT INTO t2 VALUES(25000,94666,'ninety four thousand six hundred sixty six');
COMMIT;
在SQLite當中一系列要進行多次寫入操作的時候,建議放入到事務當中去,這個優化的性能提升是可以很明顯感覺到的.用與不用的差别是非常大的.
SQLite資料不存在INSERT,存在UPDATE
SQLite的SQL文法類MySQL,在SQLite裡面有一個關鍵字REPLACE,可以使用它達到目的:

REPLACE INTO [table] (row1, row2) VALUES (2, 3);
如果該表有一個主鍵,那麼當主鍵值相等的時候,該行資料不存在執行插入,存在則執行更新操作.但是如果沒有主鍵,那麼它就執行的永遠都是插入操作了.