Web SQL Database 之 SQLite語法

 轉自:http://www.cnblogs.com/helloandroid/articles/2150272.html

id字段自增

sql="CREATE TABLE IF NOT EXISTS MusicList (id integer primary key AutoIncrement,name varchar(20),path varchar(20))";

  

<br>常用Select語句

複製代碼
desc <table> //查看錶結構 
select * from <table> //查詢所有更
select , from table ;//查看指定列
select distinct , from table ;//非重複查詢
insert into users(_id,username,password) select * from users;//複製
select username from users where username like 'S%' ;//非重名字首字母爲大寫S的用戶
select username from users where username like '__S%' ;//非重名字第三個字母爲大寫S的用戶
select * from users where _id in(001,220,230);
select * from user order by _id;//以id的順序排列
select * from user order by _id desc;//以id反的順序排
複製代碼

分頁

當數據庫數據量很大時,分頁顯示是個很簡單且符合人們習慣的一種處理方法。

獲取數據行總數:

最簡單的方法是:SELECT所有的行,再調用curosr.getCount() ;取得行數,但這樣效率會很低。 SQLite爲我們提供了一個函數很容易查出總共有多少行。有個名爲cet6_table的表格,我們想知道總共有多少行的word;可以使用如下 語句來完成:
SELECT count(word) AS number FROM cet6_table;

count()函數爲我們返回一個Int整形,代表有多少行數據。返回的列的名字叫count(word),爲了方便閱讀和處理用as number給這個列取個 別名number;

SELECT [word],[explanation] FROM cet6_table ORDER BY word LIMIT 100 OFFSET 200"

上語句,返回自第200行的最多100條數據。分頁時我們只要修改offset 後面的數據即可取得對應頁面的數據。  

SQLite內建語法表

結構定義
CREATE TABLE

創建新表。

語法:

sql-command ::= CREATE [TEMP | TEMPORARY] TABLE table-name (
    
column-def [, column-def]*
    
[, constraint]*
)
sql-command ::= CREATE [TEMP | TEMPORARY] TABLE [database-name.] table-name AS select-statement
column-def ::= name [type] [[CONSTRAINT name] column-constraint]*
type ::= typename |
typename ( number ) |
typename ( number , number )
column-constraint ::= NOT NULL [ conflict-clause ] |
PRIMARY KEY 
[sort-order] [ conflict-clause ] |
UNIQUE 
[ conflict-clause ] |
CHECK ( 
expr ) [ conflict-clause ] |
DEFAULT 
value |
COLLATE 
collation-name
constraint ::= PRIMARY KEY ( column-list ) [ conflict-clause ] |
UNIQUE ( 
column-list ) [ conflict-clause ] |
CHECK ( 
expr ) [ conflict-clause ]
conflict-clause ::= ON CONFLICT conflict-algorithm
CREATE VIEW

創建一個視圖(虛擬表),該表以另一種方式表示一個或多個表中的數據。

語法:

sql-command ::= CREATE [TEMP | TEMPORARY] VIEW [database-name.] view-name AS select-statement

例子:
CREATE VIEW master_view AS
    SELECT * FROM sqlite_master WHERE type='view';
說明:
創建一個名爲master_view的視圖,其中包括sqlite_master這個表中的所有視圖表。
CREATE TRIGGER

創建觸發器,觸發器是一種特殊的存儲過程,在用戶試圖對指定的表執行指定的數據修改語句時自動執行。

語法:

sql-statement ::= CREATE [TEMP | TEMPORARY] TRIGGER trigger-name [ BEFORE | AFTER ]
database-event ON [database-name .] table-name
trigger-action
sql-statement ::= CREATE [TEMP | TEMPORARY] TRIGGER trigger-name INSTEAD OF
database-event ON [database-name .] view-name
trigger-action
database-event ::= DELETE | 
INSERT 
| 
UPDATE 
| 
UPDATE OF 
column-list
trigger-action ::= [ FOR EACH ROW | FOR EACH STATEMENT ] [ WHEN expression ] 
BEGIN 
    
trigger-step ; [ trigger-step ; ]*
END
trigger-step ::= update-statement | insert-statement | 
delete-statement | select-statement

例子:
CREATE TRIGGER update_customer_address UPDATE OF address ON customers 
  BEGIN
    UPDATE orders SET address = new.address WHERE customer_name = old.name;
  END;
說明:
創建了一個名爲update_customer_address的觸發器,當用戶更新customers表中的address字段時,將觸發並更新orders表中的address字段爲新的值。
比如執行如下一條語句:
UPDATE customers SET address = '1 Main St.' WHERE name = 'Jack Jones';
數據庫將自動執行如下語句:
UPDATE orders SET address = '1 Main St.' WHERE customer_name = 'Jack Jones';

CREATE INDEX

爲給定表或視圖創建索引。

語法:

sql-statement ::= CREATE [UNIQUE] INDEX index-name 
ON 
[database-name .] table-name ( column-name [, column-name]* )
[ ON CONFLICT conflict-algorithm ]
column-name ::= name [ COLLATE collation-name] [ ASC | DESC ]

例子:
CREATE INDEX idx_email ON customers (email);
說明:
爲customers表中的email創建一個名爲idx_email的字段。

結構刪除
DROP TABLE

刪除表定義及該表的所有索引。

語法:

sql-command ::= DROP TABLE [database-name.] table-name
例子:
DROP TABLE customers;
DROP VIEW

刪除一個視圖。

語法:

sql-command ::= DROP VIEW view-name

例子:
DROP VIEW master_view;

DROP TRIGGER

刪除一個觸發器。

語法:

sql-statement ::= DROP TRIGGER [database-name .] trigger-name

例子:
DROP TRIGGER update_customer_address;

DROP INDEX

刪除一個索引。

語法:

sql-command ::= DROP INDEX [database-name .] index-name

例子:
DROP INDEX idx_email;

數據操作
INSERT

將新行插入到表。

語法:

sql-statement ::= INSERT [OR conflict-algorithm] INTO [database-name .] table-name [(column-list)]VALUES(value-list) |
INSERT 
[OR conflict-algorithm] INTO [database-name .] table-name [(column-list)] select-statement
UPDATE

更新表中的現有數據。

語法:

sql-statement ::= UPDATE [ OR conflict-algorithm ] [database-name .] table-name
SET 
assignment [, assignment]*
[WHERE expr]
assignment ::= column-name = expr
DELETE

從表中刪除行。

語法:

sql-statement ::= DELETE FROM [database-name .] table-name [WHERE expr]
SELECT

從表中檢索數據。

語法:

sql-statement ::= SELECT [ALL | DISTINCT] result [FROM table-list]
[WHERE expr]
[GROUP BY expr-list]
[HAVING expr]
[compound-op select]*
[ORDER BY sort-expr-list]
[LIMIT integer [( OFFSET | , ) integer]]
result ::= result-column [, result-column]*
result-column ::= * | table-name . * | expr [ [AS] string ]
table-list ::= table [join-op table join-args]*
table ::= table-name [AS alias] |
( 
select ) [AS alias]
join-op ::= , | [NATURAL] [LEFT | RIGHT | FULL] [OUTER | INNER | CROSS] JOIN
join-args ::= [ON expr] [USING ( id-list )]
sort-expr-list ::= expr [sort-order] [, expr [sort-order]]*
sort-order ::= [ COLLATE collation-name ] [ ASC | DESC ]
compound_op ::= UNION | UNION ALL | INTERSECT | EXCEPT
REPLACE

類似INSERT

語法:

sql-statement ::= REPLACE INTO [database-name .] table-name [( column-list )] VALUES ( value-list ) |
REPLACE INTO 
[database-name .] table-name [( column-list )] select-statement
事務處理
BEGIN TRANSACTION

標記一個事務的起始點。

語法:

sql-statement ::= BEGIN [TRANSACTION [name]]
END TRANSACTION

標記一個事務的終止。

語法:

sql-statement ::= END [TRANSACTION [name]]
COMMIT TRANSACTION

標誌一個事務的結束。

語法:

sql-statement ::= COMMIT [TRANSACTION [name]]
ROLLBACK TRANSACTION

將事務回滾到事務的起點。

語法:

sql-statement ::= ROLLBACK [TRANSACTION [name]]
其他操作
COPY

主要用於導入大量的數據。

語法:

sql-statement ::= COPY [ OR conflict-algorithm ] [database-name .] table-name FROM filename
[ USING DELIMITERS delim ]
例子:
COPY customers FROM customers.csv;
EXPLAIN

語法:

sql-statement ::= EXPLAIN sql-statement
PRAGMA

語法:

sql-statement ::= PRAGMA name [value] |
PRAGMA 
function(arg)
VACUUM

語法:

sql-statement ::= VACUUM [index-or-table-name]
ATTACH DATABASE

附加一個數據庫到當前的數據庫連接。

語法:

sql-statement ::= ATTACH [DATABASE] database-filename AS database-name
DETTACH DATABASE

從當前的數據庫分離一個使用ATTACH DATABASE附加的數據庫。

語法:

sql-command ::= DETACH [DATABASE] database-name

SQLite內建函數表

算術函數
abs(X) 返回給定數字表達式的絕對值。
max(X,Y[,...]) 返回表達式的最大值。
min(X,Y[,...]) 返回表達式的最小值。
random(*) 返回隨機數。
round(X[,Y]) 返回數字表達式並四捨五入爲指定的長度或精度。
字符處理函數
length(X) 返回給定字符串表達式的字符個數。
lower(X) 將大寫字符數據轉換爲小寫字符數據後返回字符表達式。
upper(X) 返回將小寫字符數據轉換爲大寫的字符表達式。
substr(X,Y,Z) 返回表達式的一部分。
randstr()  
quote(A)  
like(A,B) 確定給定的字符串是否與指定的模式匹配。
glob(A,B)  
條件判斷函數
coalesce(X,Y[,...])  
ifnull(X,Y)  
nullif(X,Y)  
集合函數
avg(X) 返回組中值的平均值。
count(X) 返回組中項目的數量。
max(X) 返回組中值的最大值。
min(X) 返回組中值的最小值。
sum(X) 返回表達式中所有值的和。
其他函數
typeof(X) 返回數據的類型。
last_insert_rowid() 返回最後插入的數據的ID。
sqlite_version(*) 返回SQLite的版本。
change_count() 返回受上一語句影響的行數。
last_statement_change_count()  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章