建表:
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’是不是一樣的我就不清楚了,沒試過,你可以試一下,你開心就好??