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沒(méi)有TRUNCATE清空表命令,所以只能這樣
DELETE FROM 21andy;
SQLite 刪除記錄后, 自增ID置0
只能這樣
DELETE FROM sqlite_sequence;
另外, 這個(gè)sqlite_sequence可以CRUD
SQLite 刪除記錄后, 不會(huì)釋放空間
必須像這樣
VACUUM
SQLite 分頁(yè)查詢有兩種寫法:
Select * From Account Limit 9 Offset 10;
SELECT * FROM Account LIMIT 10, 9
他們兩個(gè)的效果都是一樣的,其中第一種寫法比較清晰明了,即跳過(guò)10行,讀取其后的9行數(shù)據(jù).
SQLite批量插入數(shù)據(jù)很不幸的事情是貌似SQLite只能一條一條的執(zhí)行插入,但是這是非常非常慢的行為,執(zhí)行一條就是執(zhí)行一次寫入磁盤的操作,這實(shí)在是太可怕了.在SQLite里面執(zhí)行批量插入,只能將插入操作放入到事務(wù)當(dāng)中去.示例如下:
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當(dāng)中一系列要進(jìn)行多次寫入操作的時(shí)候,建議放入到事務(wù)當(dāng)中去,這個(gè)優(yōu)化的性能提升是可以很明顯感覺(jué)到的.用與不用的差別是非常大的.
SQLite數(shù)據(jù)不存在INSERT,存在UPDATESQLite的SQL語(yǔ)法類MySQL,在SQLite里面有一個(gè)關(guān)鍵字REPLACE,可以使用它達(dá)到目的:
REPLACE INTO [table] (row1, row2) VALUES (2, 3);
如果該表有一個(gè)主鍵,那么當(dāng)主鍵值相等的時(shí)候,該行數(shù)據(jù)不存在執(zhí)行插入,存在則執(zhí)行更新操作.但是如果沒(méi)有主鍵,那么它就執(zhí)行的永遠(yuǎn)都是插入操作了.
參考
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