MySQL必知必會 第4-6章

第四章 檢索數據

4.1 SELECT語句

SELECT語句的用途是從一個或多個表中檢索信息。為了使用SELECT語句檢索表數據,至少需要給出兩條信息——想選擇什么以及從什么地方選擇。

4.2 檢索單個列

輸入:
SELECT prod_name FROM products;
輸出:略
分析:從products表中檢索一個名為prod_name的列。

注意:

  • 以上輸出的數據是沒有排序的,其當前序列可能使添加到表中的順序,也可能不是,沒有特殊含義。
  • 多條SQL語句必須以分號分割。MySQL如同多數DBMS,不需要在單條SQL語句后加分號,但加上分號也沒有壞處。
  • SQL語句不區分大小寫,因此SELECTselect是相同的,甚至Select也是相同的。但一般約定對所有SQL關鍵字使用大寫,對列和表名使用小寫,以便于調試與使用。
  • 在處理SQL中,其中所有空格都被忽略,SQL可以在一行上給出,也可以分為多行。
4.3 檢索多個列

在選擇多個列時,一定要在列名之間加上逗號,但在最后一個列名上不加。
輸入:
SELECT prod_name, prod_price FROM products;
輸出:略
分析:從products表中檢索名為prod_nameprod_price的列。

4.4 檢索所有列

除了指定所需要的列外(一個或多個),SELECT語句還可以檢索所有的列而非逐個將其列出。這可以通過在實際列名的位置使用星號*通配符實現。
輸入:
SELECT * FROM products;
輸出:略
分析:通過通配符(*),匹配出所有的列。除非確實需要表中的每個列,否則最好別使用通配符(*),檢索 不需要的列通常會降低檢索和使用程序的性能。

4.5 檢索不同的行

SELECT返回所有匹配的行,如果想讓相同的行只出現一次,則需要使用DISTINCT關鍵字
輸入:
SELECT DISTINCT vend_id FROM products;
輸出:略
分析:DISTINCT關鍵字必須在列名前使用。

4.6 限制結果

SELECT返回所有匹配的行,如果要控制返回的行數與行號,可以使用LIMIT關鍵字。
輸入:
SELECT prod_name FROM products LIMIT 5;
輸出:略
分析:此語句使用SELECT檢索單個列,LIMIT 5指示MySQL返回不多于5行(至多0-4行)。

為得出下一個5行,可指定要檢索的開始行和行數:
輸入:
SELECT prod_name FROM products LIMIT 5,5;
輸出:略
分析:LIMIT 5,5指示MySQL返回從行5開始的5行,第一個數字為開始位置,第二個數為要檢索的行數。

注意:

  • 檢索的第一行為行0。因此,LIMIT 1,1檢索出來的是第二行。
  • 在行數不夠時,MySQL返回其能夠提供的所有行。
  • MySQL 5 支持使用 LIMIT 4 OFFSET 3等價于 LIMIT 3,4表示從行3開始取4行。
4.7 使用完全限定的表名

輸入:
SELECT products.prod_name FROM products;

SELECT products.prod_name FROM crashcourse.products;
輸出:略
分析:第一條語句完全限制了列名,第二條語句還嚴格限制了表名。有一些情形需要完全限定名,現在,請知曉這個語法。

第五章 排序檢索數據

5.1 排序數據

如果沒有明確規定排序順序,則不應該假定檢索出的數據的順序有意義。SQL語言由子句(clause)構成,有些子句是必須的,而有些是可選的,為了明確排序SELECT的檢索結果,可使用ORDER BY子句。
輸入:
SELECT prod_name FROM products ORDER BY prod_name;
輸出:略
分析:ORDER BY prod_name指示MySQL對SELECT語句的檢索結果以prod_name列字母順序進行排序。

注意:使用非檢索的列排序數據是完全合法的。

5.2 按多個列排序

按多個列排序時,只需要指定列名,列名間用逗號分隔開即可。使用前,注意理解其含義,排序結果首先按照第一列排序,如果第一列結果相同,再按照第二列進行排序,以此類推。
輸入:
SELECT prod_id, prod_price, prod_name FROM products ORDER BY prod_price, prod_name;
輸出:略
分析:對檢索結果先按照prod_price排序,二者相等時,再按照prod_name排序。

5.3 指定排序方向

數據排序默認為升序排序,但可以使用DESC關鍵字指示MySQL對檢索結果以降序排序。
輸入:
SELECT prod_id, prod_price, prod_name FROM products ORDER BY prod_price DESC;
輸出:略
分析:對檢索結果按照prod_price以降序排序。

DESC關鍵字只應用于直接位于其前面的列名。如果需要對多個列調整排序方式,則需要分別指定。
SELECT prod_id, prod_price, prod_name FROM products ORDER BY prod_price DESC, prod_name;
輸出:略
分析:對檢索結果按照prod_price以降序排序,prod_price相同時,按照prod_name以升序排列。

使用ORBER BY和LIMIT的組合,可以找到一個列中最大或最小值。
輸入:
SELECT prod_price FROM products ORDER BY prod_price DESC LIMIT 1;
輸出:略
分析:返回prod_price最大值。

注意:

  • DESC相反的關鍵詞是ASC,由于排序默認是升序的,因此ASC很少使用。
  • 在字典排序中,A與a視為相同,這是默認行為,如果需要改變這種行為,ORBER BY語句無法實現,必須請求數據庫管理員更改配置。
  • ORDER BY子句必須保證位于FROM子句之后。

第六章 過濾數據

6.1 使用WHERE子句

數據庫一般包含大量的數據,很少需要檢索表中所有行。通常需要通過WHERE子句給檢索指定搜索條件(過濾條件)。
輸入:
SELECT prod_name, prod_price FROM products WHERE prod_price = 2.50;
輸出:略
分析:從products中檢索兩個列,并選取其中prod_price = 2.50 的列返回。

** 注意:**在同時使用ORDER BYWHERE子句時,應讓ORDER BY位于WHERE之后。

6.2 WHERE子句操作符

MySQL允許的搜索條件不僅僅是相等測試,MySQL支持的所有操作符如下。


6.2.1 檢索單個值

單引號用來限定字符串。如果將值與串類型的列進行比較,則需要限定引號。用來與數值列進行比較時,則不需要使用引號。
輸入:
SELECT prod_name, prod_price FROM products WHERE prod_name = 'fuses';
輸出:略
分析:MySQL在匹配時不分大小寫,fusesFuses一行相匹配。

類似的,我們可以分別修改WHERE子句為WHERE prod_price < 10WHERE prod_price <= 10 來指示MySQL檢索prod_price小于10,或小于等于10的行。

6.2.2 不匹配檢查

輸入:
SELECT vend_id, prod_name FROM products WHERE vend_id <> 1003:
輸出:略
分析:列出的是不由供應商1003制造的所有產品

6.2.3 范圍值檢查

為了檢查某個范圍的值,可以使用BETWEEN操作符。其語法與其他WHERE子句稍有不同,需要提供兩個參數作為范圍最低值和最高值。
輸入:
SELECT prod_name, prod_price FROM products WHERE prod_price BETWEEN 5 AND 10;
輸出:略
分析:BETWEEN的兩個參數由AND間隔開,5和10分別是開始值和結束值。

6.2.4 空值檢查

在創建表時,表設計人員可以指定其中的列是否可以不包含值,一個列不包含值時,稱其值為空值NULL(與包含0、空字符串或僅包含空格不同)。用來檢測NULL值的是IS NULL子句。
輸入:
SELECT prod_name FROM products WHERE prod_price IS NULL;
輸出:略
分析:返回沒有價格的所有產品。

注意:在匹配過濾和不匹配過濾時,并不返回NULL值的列。這是由于未知具有特殊含義,數據庫無法進行匹配。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,443評論 6 532
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,530評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,407評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,981評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,759評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,204評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,263評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,415評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,955評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,650評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,892評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,675評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,967評論 2 374

推薦閱讀更多精彩內容

  • 前言 一、基礎知識1.了解數據庫數據庫(database):保存有組織的數據的容器表(table):某種特定類型數...
    流水混帳閱讀 519評論 0 1
  • 數據庫入門 數據庫: 保存有組織的數據的容器(通常是一個文件或一組文件).數據庫軟件應該稱為 DBMS(DataB...
    Mjericho閱讀 508評論 0 0
  • 1.表中的任何列都可以作為主鍵, 只要它滿足以下條件:任意兩行都不具有相同的主鍵值;每一行都必須具有一個主鍵值( ...
    Cherryjs閱讀 683評論 0 0
  • 第七章 數據過濾 7.1 組合WHERE子句 在第六章介紹的所有WHERE子句在過濾時,使用的都是單一的條件。為了...
    saviochen閱讀 432評論 0 4
  • 于是又到了梧桐絮飄滿校園的四月,又到了梧桐色相簿的季節,我們迎來了實習生招聘。 “范老濕從不寫代碼”,“范老濕從不...
    Lance_Van閱讀 748評論 0 1