SQLite常用語句

建表:
CREATE TABLE 表名稱 (列名稱1 數(shù)據(jù)類型,列名稱2 數(shù)據(jù)類型,列名稱3 數(shù)據(jù)類型)

** SELECT語句**
下面以名字叫做** Persons**的表為例:
1、從“ Persons”表中選取 LastName 列的數(shù)據(jù):
SELECT LastName FROM Persons

2、獲取名為 "LastName" 和 "FirstName" 的列的內(nèi)容
SELECT LastName,FirstName FROM Persons

3、“ Persons”表中選取所有的列
SELECT * FROM Persons【星號(*)是選取所有列的快捷方式。】

4、“ Persons”表中獲取“ Company”列所有不重復(fù)【相同數(shù)據(jù)只統(tǒng)計一次】的數(shù)據(jù)
SELECT DISTINCT Company FROM Persons

插入語句【增】:INSERT INTO 表名稱 VALUES (值1, 值2,....)
1、向“ Persons”表中插入一條數(shù)據(jù)
INSERT INTO Persons VALUES ('Gates', 'Bill', 'Xuanwumen 10', 'Beijing')

2、向“ Persons”表指定列中插入一條數(shù)據(jù)
INSERT INTO Persons (列1, 列2,...) VALUES (值1, 值2,....)

刪除語句【刪】:DELETE FROM 表名稱 WHERE 列名稱 = 值
1、在“ Person”表中刪除LastName列值為'Wilson'的行
DELETE FROM Person WHERE LastName = 'Wilson'

2、刪除所有行【清空“ Person”表,但是保留表結(jié)構(gòu)、屬性和索引】
DELETE FROM Person 或者 DELETE * FROM Person

修改語句【改】:UPDATE 表名稱 SET 列名稱 = 新值 WHERE 列名稱 = 某值

1、更新“ Person”中“ LastName”為'Wilson',并將其“ FirstName”列的值改為'Fred'
UPDATE Person SET FirstName = 'Fred' WHERE LastName = 'Wilson'

2、更新“ Person”中“ LastName”為'Wilson'行中,Address以及City列的值修改為'Zhongshan 23','Nanjing'
UPDATE Person SET Address = 'Zhongshan 23', City = 'Nanjing'
WHERE LastName = 'Wilson'

查詢語句【查】:【SELECT 列名稱 FROM 表名稱 WHERE 列 運算符 值】
首先認(rèn)識一下運算符:【= 等于】、【<> 不等于 】、【> 大于】、【< 大于】、【>= 大于等于】、【<= 小于等于】、【BETWEEN 在某個范圍內(nèi)】、【LIKE 類似某種模式】。注釋:在某些版本的 SQL 中,操作符 <> 可以寫為 !=。

1、只希望在“Persions”表中選取居住在城市 "Beijing" 中的人
SELECT * FROM Persons WHERE City='Beijing'

注意:SQL 使用單引號來環(huán)繞文本值(大部分?jǐn)?shù)據(jù)庫系統(tǒng)也接受雙引號)。如果是數(shù)值,請不要使用引號。

多條件查詢語句【查】:【AND 和 OR 運算符】:
AND 和 OR 可在 WHERE 子語句中把兩個或多個條件結(jié)合起來。
如果第一個條件和第二個條件都成立,則 AND 運算符顯示一條記錄。
如果第一個條件和第二個條件中只要有一個成立,則 OR 運算符顯示一條記錄。
1、使用 AND 來顯示所有姓為 "Carter" 并且名為 "Thomas" 的人:
SELECT * FROM Persons WHERE FirstName='Thomas' AND LastName='Carter'

2、使用 OR 來顯示所有姓為 "Carter" 或者名為 "Thomas" 的人:
SELECT * FROM Persons WHERE firstname='Thomas' OR lastname='Carter'

3、我們也可以把 AND 和 OR 結(jié)合起來(使用圓括號來組成復(fù)雜的表達(dá)式):
SELECT * FROM Persons WHERE (FirstName='Thomas' OR FirstName='William')
AND LastName='Carter'
注釋:表示搜索“ Persons”表中姓為'Thomas'或者'William' 并且名為'Carter'的人

排序:【ORDER BY 】
ORDER BY 語句用于根據(jù)指定的列對結(jié)果集進(jìn)行排序【默認(rèn)按照升序】。
如果您希望按照降序?qū)τ涗涍M(jìn)行排序,可以使用 DESC 關(guān)鍵字。
1、在“ ORDER”表中,以“ Company”字母順序顯示公司名稱:
SELECT Company, OrderNumber FROM Orders ORDER BY Company

2、以逆字母順序顯示公司名稱:
SELECT Company, OrderNumber FROM Orders ORDER BY Company ** DESC**

3、以字母順序顯示公司名稱(Company),并以數(shù)字順序顯示順序號(OrderNumber):
SELECT Company, OrderNumber FROM Orders ORDER BY Company, OrderNumber

模糊查詢【查】
首先了解一下SQL通配符:
【% 替代一個或多個字符】、【_ 僅替代一個字符】、【[charlist] 字符列中的任何單一字符】、【[^charlist] 或者 [!charlist] 不在字符列中的任何單一字符】
1、 "Persons" 表中選取居住在城市名稱以 "Ne" 開始的人
SELECT * FROM Persons WHERE City LIKE 'Ne%'

2、 "Persons" 表中選取居住在包含 "lond" 的城市里的人
SELECT * FROM Persons WHERE City LIKE '%lond%'

3、"Persons" 表中選取名字的第一個字符之后是 "eorge" 的人
SELECT * FROM Persons WHERE FirstName LIKE '_eorge'

4、"Persons" 表中選取的這條記錄的姓氏以 "C" 開頭,然后是一個任意字符,然后是 "r",然后是任意字符,然后是 "er"
SELECT * FROM Persons WHERE LastName LIKE 'C_r_er'

** [charlist] 示例**
5、"Persons" 表中選取居住的城市以 "A" 或 "L" 或 "N" 開頭的人
SELECT * FROM Persons WHERE City LIKE '[ALN]%'

6、 "Persons" 表中選取居住的城市不以 "A" 或 "L" 或 "N" 開頭的人
SELECT * FROM Persons WHERE City LIKE '[!ALN]%'

注: [charlist] 格式類似正則表達(dá)式的用法,有興趣可以看下這里的正則表達(dá)式教程

就先寫這么多吧,我平時用到的也不多,而且現(xiàn)在準(zhǔn)備轉(zhuǎn)戰(zhàn)蘋果封裝的SQLite----->CoreData了??

另外補充一點:SQL 對大小寫不敏感!也就是‘ SELECT’ 和 ‘select’ 是一樣的,但是和‘sELect’是不是一樣的我就不清楚了,沒試過,你可以試一下,你開心就好??

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 學(xué)習(xí)web安全足足有一個半月有余,之前學(xué)的是前端,也會一點python。。好吧差不多忘了。常規(guī)工具算是熟悉基本...
    一葉紅塵哦喲閱讀 3,479評論 4 92
  • 如果只希望選住在 "Beijing" 的人,則向 SELECT 語句添加 WHERE 子句: SELECT * F...
    zhengjuan閱讀 1,381評論 0 1
  • SQL 是用于訪問和處理數(shù)據(jù)庫的標(biāo)準(zhǔn)的計算機語言。 什么是 SQL? SQL 指結(jié)構(gòu)化查詢語言SQL 使我們有能力...
    鹿守心畔光閱讀 726評論 0 0
  • 1.創(chuàng)建表 create table if not exists 表名(字段名 類型(字符個數(shù),可以省略) pri...
    面試題大神閱讀 579評論 0 2
  • SQL 對大小寫不敏感! DML(數(shù)據(jù)操作語言)部分: select- 從數(shù)據(jù)表中獲取數(shù)據(jù) update - 更新...
    志城閱讀 506評論 0 4

友情鏈接更多精彩內(nèi)容