MySQL學習總結(五) --- 表資料查詢

來源:互聯網
上載者:User

標籤:

查詢資料記錄,是指從資料庫物件表中擷取所要查詢的資料記錄,該操作可以說是資料最基本的操作之一,也是使用頻率最高、最重要的資料操作。

1、單表資料記錄查詢

 

1.1、簡單資料查詢

SELECT field1,field2,…,fieldn FROM table_name,filed可以是表中所有的欄位,也可以是部分欄位。

SELECT * FROM table_name ,從表中查詢所有的資料。*符號可以代替所有的欄位,但是這種方式不夠靈活,只能按照表中欄位的順序固定進行顯示,不能夠隨便改變欄位的顯示順序。

 

1.2、避免重複資料查詢

例如查詢僱員表中,job的資料,僱員表的資料如下:

我們從資料表中發現工作一列的記錄資料是有重複的,如果直接查詢  SELECT job FROM t_emp,會發現結果也是有重複的,此時我們需要一個關鍵字 DISTINCT,SELECT DISTINCT job FROM t_emp,此時就會將結果重複的記錄給去除了,如下:

同理,我們也可以去除多列的重複的欄位,DISTINCT後面的所有的欄位只要有一個欄位不一樣,就表示不是重複記錄。例如SELECT DISTINCT job,mgr FROM t_emp 和 SELECT DISTINCT mgr,job FROM t_emp ,雖然查詢欄位的順序不一樣但是記錄結果是一致的。

 

1.3、在查詢中實現運算

例如在員工表中,已經有了員工的工資了,但是我們想要員工的年薪,則可以如此實現:SELECT ename,sal,sal*12 AS yearsal FROM t_emp ,其中AS是MySQL中提供的一種修改欄位名的機制。AS也可以不要,直接寫欄位名。

 

1.4、條件資料查詢

SELECT field1,field2,…,fieldn FROM table_name WHERE CONDITION,前面我們已經介紹過關於關係運算子。

查詢範圍內的記錄資料:SELECT ename,sal FROM t_emp WHERE sal BETWEEN 1000 AND 2000.

查詢某項工作的員工記錄資料:SELECT ename,job FROM t_emp WHERE job=‘CLERK‘.

查詢某個集合內記錄資料,SELECT field1,field2,…,fieldn FROM table_name WHERE  filed in(value1,value2,…,valuen)

 

查詢不在集合內的記錄資料,SELECT field1,field2,…,fieldn FROM table_name WHERE  filed NOT in(value1,value2,…,valuen)

注意:如果查詢集合中有NULL值的話,使用IN的時候查詢結果不會有改變,使用NOT IN的時候,則不會有任何結果。

模糊查詢:例如查詢以字母M開頭的員工的資料記錄,

 

1.5、排序查詢

SELECT field1,field2,…,fieldn FROM table_name WHERE CONDITION ORDER BY field

ASC 升序,DESC 降序,預設是升序排序。

例如:SELECT * FROM t_emp ORDER BY sal ASC,hiredate DESC,這表示先按工資升序排序,再按日期降序排序。

 

1.6、限制查詢資料

SELECT field1,field2,…,fieldn FROM table_name WHERE CONDITION LIMIT OFFSET_START,ROW_COUNT,

OFFSET_START 表示資料記錄的起始位移量,ROW_COUNT表示要查詢的資料條數。其中OFFSET_START可以指定也可以不指定,LIMIT關鍵字經常被應用於分頁系統中。

不指定初始位置,如果顯示記錄數小於總的記錄數,則會顯示指定的條數。如果顯示的記錄數大於總的記錄數,則會顯示所有的記錄數。

指定初始位置,LIMIT 0,5,表示從第一條記錄開始顯示,共顯示5條記錄, LIMIT 5,5,表示從第六條記錄開始,共顯示5條記錄。

 

1.7、統計函數

COUNT(),統計表中的記錄數

AVG(),計算某個欄位的平均值

SUM(),計算某個欄位的和

MAX().計算某個欄位的最大值

MIN(),計算某個欄位的最小值

在實際應用中,統計函數經常與分組一起使用,對於MySQL所支援的統計函數,如果所操作的表中沒有任何資料記錄,COUNT函數返回0,其他的返回NULL。

分組GROUP BY。如果想要顯示每個分組的欄位的話,則可以通過函數GROUP_CONCAT() 來顯示。

例如,將員工表按照部門號分組,並且顯示每組中員工的個數以及名字。

 

如果想對分組進行條件限制,絕對不能通過關鍵字WHERE來實現,因為該關鍵字主要是用來實現條件限制資料記錄,可以通過HAVING來實現條件限制分組記錄資料。

例如,對員工表按照部門進行分組,然後顯示每組平均工資高於2000的員工名字。

 

2、多表資料記錄查詢

MySQL中可以通過兩種文法形式來實現串連查詢,一種是在FROM子句中利用逗號區分多個表,在WHERE子句中通過邏輯運算式來實現匹配條件從而實現表的串連。另一種方式,在FROM子句中使用JOIN…ON關鍵字,而串連條件寫在ON子句中,推薦使用第二種方式。

第一種文法:SELECT filed1,field2…fieldn FROM table_name1,table_name2 WHERE table_name1.fieldx=table_name2.fieldy.

第二種文法:SELECT filed1,field2…fieldn FROM table_name1 JOIN table_name2 ON table_name1.fieldx=table_name2.fieldy.

 

2.1、內串連查詢

內串連可以是多個表的串連,也可以是一個表的串連也稱之為自串連。

例如,在員工表中查詢每一個員工的姓名、職位以及領導名字。通過分析,我們可以知道,員工的領導同樣也是員工,這就是自串連。

 

2.2、外串連查詢

外串連可以分為三種,左外串連LEFT、右外串連RIGHT、全外串連FULL。

左外串連指的是新關係中執行匹配條件時以關鍵字LEFT JOIN左邊的表為參考表,如果左邊表中資料對應的右邊表沒有資料的時候,依然會顯示,而INNER JOIN則會去掉該條記錄。

同樣是上面的例子,如果是左串連的時候查詢結果會有不同,如下所示:

 

右外串連指的是新關係中執行匹配條件時以關鍵字RIGHT JOIN右邊的表為參考表,如果右邊表中資料對應的左邊表沒有資料的時候,依然會顯示,而INNER JOIN則會去掉該條記錄。

 

2.3、合并查詢資料記錄

在MySQL中可以通過關鍵字UNION來實現並操作,可以將多個SELECT語句查詢結果合并在一起。

UNION 會把查詢結果直接合并在一起,同時會去掉重複的資料記錄。

UNION ALL會把查詢結果直接合并在一起,並沒有去掉重複的記錄。

 

2.4、子查詢

所謂的子查詢就是指一個查詢之中嵌套了其他的若干個查詢,即在一個SELECT查詢語句的WHERE或這FROM子句中包含另一個SELECT查詢語句。

2.4.1、子查詢結果返回單行單列

例,查詢員工表中,工資比員工SMITH工資高的員工資訊。

2.4.2、子查詢結果返回單行多列

例,查詢員工表中,工資和置為都和員工SMITH一樣的所有的員工資訊。

 

2.4.3、子查詢結果返回多行多列

此時,子查詢語句一般會在主查詢語句的WHERE子句裡出現,並且通常會包含IN、ANY、ALL、EXISTS等關鍵字。

關鍵字ANY用來表示主查詢的條件滿足子查詢返回結果中的任意一條記錄。

=ANY 其功能與IN一樣,

>ANY 比子查詢中返回資料記錄中的最小的還要大的資料記錄。

<ANY 比子查詢中返回資料記錄中的最大的還要小的資料記錄。

關鍵字ALL用來表示主查詢的條件為滿足子查詢返回結果中所有資料記錄。

>ALL 比子查詢返回資料記錄還要大的資料記錄。

<ALL 比子查詢返回資料記錄還要小的資料記錄。

MySQL學習總結(五) --- 表資料查詢

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.