本文根據《MySQL必知必會》(Ben Forta著,2009)整理,基於MySQL4.1-5,可作為深入研究MySQL之前的漱口篇。(基本語句、正則表達式、聯結、全文本搜索、增刪改查、存儲過程、游標、觸發器、事務、索引)。 ...
本文根據《MySQL必知必會》(Ben Forta著,2009)整理,基於MySQL4.1-5,可作為深入研究MySQL之前的漱口篇。(基本語句、正則表達式、聯結、全文本搜索、增刪改查、存儲過程、游標、觸發器、事務、索引)。
基本語句
limit:使用limit(x,y)進行分頁等;
NULL判斷:Select xxx from yyy where xxx IS NULL;
優先順序:Select prod_name,prod_price from products where vend_id=1002 or vend_id=1003 and prod_price>=10;And 優先於 or;
匹配:%與_,後者匹配單個字元;
去空:RTrim(xxx),去掉值右邊所有空格;LTrim(xxx),去掉值左邊空格;Trim(),去掉兩邊空格;
拼接,重命名:Select concat(vend_name,’(’,vend_country,’)’)as vend_file from vendors;
字元串處理:Left()、Length()、Locate()找一個串的子串、Lower()大轉小、Right()、Soundex()、SubString()、Upper()小轉大;
日期時間:AddDate()、AddTime()、CurDate()、CurTime()、Date()、DateDiff()、Date_Add()、Date_Format()、Day()、DayOfWeek()、Hour()、Minute()、Month()、Now()、Second()、Time()、Year()。MySQL的日期格式:yyyy-mm-dd;
數據處理:Abs()絕對值、Cos()、Exp()指數、Mod()除餘、Pi()、Rand()隨機、Sin()、Sqrt()平方根、Tan();
聚集:AVG()平均值、COUNT()行數、MAX()最大值、MIN()最小值、SUM()求和;
Select子句順序:select,from,where,group by,having,order by,limit
正則表達式
REGEXP:Prod_name包含文本1000的:select prod_name from products where prod_name REGEXP’1000’ order by prod_name;
匹配任意一個字元:… where prod_name REGEXP’.000’;
BINARY:正則匹配不區分大小寫,匹配要加BINARY,如:where prod_name REGEXP BINARY ‘JetPack.000’;
OR匹配:where prod_name REGEXP ‘1000|2000’;
匹配幾個字元之一:where prod_name REGEXP ‘[123]Ton’;
匹配範圍:where prod_name REGEXP’[1-5]Ton’;
匹配特殊字元需要轉義:where vend_name REGEXP’\\.’;
\\也用於元字元:\\f換頁,\\n換行,\\t製表,\\r回車,\\v縱向製表;
聯結與組合
等值聯結:
笛卡爾積:
Select vend_name,prod_name,prod_price from vendors,products order by vend_name,prod_name;
內部聯結:
自聯結:
等價於:
自然聯結(排除多次出現,每個列只返回一次):
外部聯結(包含了在相關表中沒有關聯行的行):
Left(right) outer join:左(右)邊表中選中所有行;
全文本搜索
MySQL常用的兩種引擎:MyISAM(支持全文搜索)InnoDB(不支持全文搜索);
啟動全文本搜索:
方法:Macth()+Against()
等價於:
前者是按等級降序,後者不會;前者有索引,更快。
可以在select中加一個計算列:
查詢擴展:MySQL對數據和索引進行兩遍掃描,第一遍進行基本的全文搜索,找出與條件匹配的所有行àMySQL檢查這些匹配行,選擇所有有用的詞àMySQL再進行全文搜索,使用原來條件+所有有用的詞。
增刪改查
一般刪除用delete,更快刪除用truncate table(刪除原來的表,新建一個表)。
Mysql沒有撤銷按鈕,需要小心使用update和delete。
創建表:
創建多個主鍵:
主鍵是單個,則單個列值唯一,主鍵時多個,則多個組合起來唯一。
Select last_insert_id()返回最後一個AUTO_INCREMENT值。
引擎類型:MySQL有一個具體管理和處理數據的內部引擎,通過引擎創建表,內部處理你的查詢等請求。
三種引擎:InnoDB,可靠的事務處理引擎,不支持全文本搜索;MEMORY功能等同於MyISAM,但數據存儲在記憶體(不是磁碟中),速度快(適合臨時表);MyISAM,性能極高,支持全文本搜索,不支持事務處理;
增加列:alter table vendors add vend_phone char(20);
刪除列:alter table vendors drop column vend_phone;
存儲過程
創建存儲過程:
調用存儲過程:
刪除:
使用參數:
調用帶參存儲過程:
獲取結果:
同時使用IN和OUT:
調用IN和OUT存儲過程:
智能存儲過程:
顯示用來創建一個存儲過程的create語句:
SHOW CREATE PROCEDURE ordertotal;
獲得何時、由誰創建等詳細信息:
SHOW PROCEDURE STATUS LIKE ‘ordertotal’;
游標
游標是一個存儲在MySQL伺服器上的資料庫查詢,是被查詢語句檢索出來的結果集。存儲游標後,應用程式根據需要滾動或瀏覽數據。MySQL游標只能用於存儲過程(和函數)。
創建游標:
存儲過程處理完成後,游標即消失(僅用於存儲過程)。
打開游標:
OPEN ordernumbers;
關閉游標:
CLOSE ordernumbers;
使用FETCH訪問游標的每一行,指定檢索什麼數據(列),檢索的數據存在何處,向前移動游標的內部行指針以檢索下一行:
使用游標迴圈檢索數據(你可以在迴圈內放入任何需要的處理):
對取出的數據做一個實際的處理:
觸發器
在某個表發生更改時(DELETE、INSERT、UPDATE)自動處理某些事情。
創建觸發器:需要給出四條信息:唯一的觸發器名、關聯的表、應該響應的活動(刪除、插入、更新)、何時執行(處理前、後)。
觸發器僅支持表(視圖、臨時表均不支持)。
刪除觸發器:
INSERT觸發器:使用NEW虛擬表訪問被插入的行。
DELETE觸發器:引用OLD虛擬表訪問被刪除的行:
上例使用BEGIN…END為非必須,BEGIN…END的好處:可容納多條SQL語句。
UPDATE觸發器:引用OLD訪問更新前的值,引用NEW訪問更新後的值。
事務
事務處理用來維護資料庫的完整性,它保證成批的MySQL要麼完全執行,要麼完全不執行。
關於事務的名詞:回退、提交、保留點(事務處理中設定的臨時占位符,可對它發佈回退)。
事務的開始:
使用ROLLBACK:
使用COMMIT:一般的MySQL預設自動提交。但在事務處理塊兒中,提交不會預設進行:
使用保留點:簡單的ROLLBACK和COMMIT會寫入或撤銷整個事務處理。複雜的事務處理需要部分提交或回退。這時需要在事務處理塊兒的合適位置放置占位符。
更改預設的提交行為:
索引
創建索引(INDEX:普通;PRIMARY KEY:唯一且不能為空;UNIQUE:唯一且不允許重覆):
刪除索引:
更多精彩掃描本人微信公眾號二維碼(it_pupil)