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,存在UPDATESQLite的SQL語法類MySQL,在SQLite里面有一個關鍵字REPLACE,可以使用它達到目的:
REPLACE INTO [table] (row1, row2) VALUES (2, 3);
如果該表有一個主鍵,那么當主鍵值相等的時候,該行數據不存在執行插入,存在則執行更新操作.但是如果沒有主鍵,那么它就執行的永遠都是插入操作了.
參考
1. http://www.21andy.com/blog/20090512/1272.html2. http://i.cnsoftware.cn/space-3-do-thread-id-35.html3. http://www.cnblogs.com/devsdk/archive/2009/04/03/1428615.html