1. 程式人生 > 資料庫 >Mysql資料庫之常用sql語句進階與總結

Mysql資料庫之常用sql語句進階與總結

本文例項講述了Mysql資料庫之常用sql語句。分享給大家供大家參考,具體如下:

前面講述了Mysql sql基本語句。這裡繼續總結一下SQL語句的進階內容。

SQL語句進階

1.查詢欄位:

————查詢所有欄位

select * from 表名;

————查詢指定欄位

select 欄位名,欄位名… from 表名;

————多資料表連線查詢時

select 表名.欄位名,表名.欄位名 … from 表名;

————使用as給表起別名

select 表別名.欄位名 from 表名 as 表別名;

————消除重複行(distinct)

select distinct 欄位名 from 表名;

2.條件查詢:

————比較運算子(>,<,=,!=)

select * from 表名 where age >18; 

(<>也表示!=)

————邏輯運算子(and,or,not)

select * from 表名 where age>18 and age<28;(18

3.排序:

————升序

select * from 表名 order by asc;(預設為升需asc,可以省略asc)

————降序

select * from 表名 order by desc;

4.聚合函式:

————總數count

select count(*) from 表名;

————最大值max

select max(age) from 表名;

————最小值min

select min(age) from 表名;

————求和sum

select sum(age) from 表名;

————求平均值avg

select avg(age) from 表名;

————四捨五入保留小數round

select round(avg(age),2) from 表名;(查詢平均年齡,四捨五入保留兩位小數)

5.分組(重點):

————分組group by

select gender count(*) from 表名 group by gender;(按性別分組,查詢性別與人數)

————分組查詢(聚合函式,group_concat(),having)

select gender avg(age) from 表名 group by gender;(查詢每種性別的平均年齡)

select gender group_concat(name) from 表名 group by gender;(group_concat(name)檢視分組姓名)

select gender count() from 表名 group by gender having count()>2(having類似where,過濾條件,having只能用於group by,where用於表資料)

————彙總with rollup

select gender count(*) from 表名 group by gender with rollup;(最後新增一行,顯示彙總結果)

6.分頁:

————查詢前n個數據(limit一般寫在最好,表示對操作後的資料顯示)

select * from 表名 limit n;

————分頁顯示

select * from 表名 limit 0,3;(每頁顯示3個,第1個頁面) 
select * from 表名 limit 3,3;(每頁顯示3個,第2個頁面) 
select * from 表名 limit 6,3;(每頁顯示3個,第3個頁面)

7.連線查詢(重點):

————inner join…on(內連線)

select * from 表名1 inner join 表名2 on 表名1.cls_id=表名2.id;(將表1cls.id和表2id相同的連線在一起) 
select 表名1.欄位名1,表名2.欄位名.2 from 表名1 inner jion 表明2 on 條件;

————left/right join…on(左/右/外連線)

select * from 表名1 left/right join 表名2 on 表名1.cls_id=表名2.id;(查詢的結果為兩個表匹配到的資料和左表特有的資料,對於左/右表中不存在的資料使用null填充)

8.子查詢:

————標量子查詢(子查詢返回的結果是一個數據(一行一列))

select * from 表名 where age > (select avg(age) from 表名);

————列子查詢(返回的結果是一列(一列多行))

select name from 表名1 where id in (select cls_id from 表名2);

————行子查詢(返回的結果是一行(一行多列))

select * from 表名 where (height,age) = (select max(height),max(age) from 表名);

更多關於MySQL相關內容感興趣的讀者可檢視本站專題:《MySQL查詢技巧大全》、《MySQL常用函式大彙總》、《MySQL日誌操作技巧大全》、《MySQL事務操作技巧彙總》、《MySQL儲存過程技巧大全》及《MySQL資料庫鎖相關技巧彙總》

希望本文所述對大家MySQL資料庫計有所幫助。