標籤:
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 );
如果該表有一個主鍵,那麼當主索引值相等的時候,該行資料不存在執行插入,存在則執行更新操作.但是如果沒有主鍵,那麼它就執行的永遠都是插入操作了.
SQLite 使用ISNULL函數 SQLite的SQL文法類不同於MySQL, 不可以用ISNULL,但可以用 IFNULL 直接代替
ifnull(null,0)
一些 SQLite技巧