天天看點

一些SQLite技巧

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,可以使用它達到目的:

一些SQLite技巧

REPLACE INTO [table] (row1, row2) VALUES (2, 3);

如果該表有一個主鍵,那麼當主鍵值相等的時候,該行資料不存在執行插入,存在則執行更新操作.但是如果沒有主鍵,那麼它就執行的永遠都是插入操作了.