国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

Mysql數據庫之常用sql語句進階與總結

2020-01-18 20:38:34
字體:
來源:轉載
供稿:網友

本文實例講述了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數據庫計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 江都市| 台北县| 华坪县| 温州市| 嘉定区| 安仁县| 建湖县| 建水县| 敦煌市| 五峰| 宜都市| 左贡县| 林周县| 张家界市| 阿合奇县| 清水县| 深圳市| 札达县| 合肥市| 拜泉县| 楚雄市| 涞源县| 盐边县| 天长市| 宝清县| 上杭县| 昭通市| 宁波市| 烟台市| 犍为县| 津南区| 花莲市| 台北县| 青川县| 应城市| 平阳县| 卢湾区| 遵义县| 芷江| 仲巴县| 罗定市|