国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

關于Mysql子查詢的三個應用場景

瀏覽:2日期:2023-07-20 19:52:12

應用場景

一個select語句的查詢結果能夠作為另一個語句的輸入值,主要有三種情況,分別為:

1.子查詢可以出現在Where子句中,作為過濾條件

select 列名from 表名where 列 操作符 (select 列名 from 表名)

2.也可以出現在from子句中,作為一個臨時表使用

select 列名from (select 列名 from 表名)

3.能夠出現在select list中,作為一個字段值來返回

select 列名,(select 列名 from 表名)from 表名where 列 操作符?????

注意事項:

子查詢只能有一個字段的情況子查詢在select上面,一定是只能一個字段;如果超過一個字段,代碼會報錯子查詢在where后面,當做一個過濾條件,這個字段也必須有且只有一個可以有多個字段的情況當子查詢在from后面,是可以有多個字段的,因為他就是一張表;注意:子查詢在from后面做臨時表來用,必須給子查詢生成的臨時表取別名,否則會報錯時間型字符,在 where 過濾如果是常量,需要用''; 數字則不需要子查詢中,表是可以不一樣的

???????子查詢在Where中作過濾條件

2017年7月2號統計累計購買金額在100到200的會員,尋找這批會員的消費記錄

先找出當日累計購買金額在100-200之間的會員 用having來篩選用查找出來的會員做過濾條件,查找消費記錄-- 先找出當日累計購買金額在100-200之間的會員SELECT dimMemberID ,SUM(AMT) as moneyFROM dw.fct_saleswhere dimDateID ='20170702'and dimMemberID <> 0group by dimMemberID-- having sum(AMT)>100 and sum(AMT)<200;having money BETWEEN 100 and 200;-- 用查找出來的會員做過濾條件,查找消費記錄SELECT *FROM dw.fct_saleswhere dimDateID = '20170702'and dimMemberID <>0and dimMemberID in ( SELECT dimMemberID-- ,SUM(AMT) as money 子查詢在where后面,當做一個過濾條件,這個字段也必須有且只有一個,所以最后結果要返回過濾條件 FROM dw.fct_sales where dimDateID ='20170702' and dimMemberID <> 0 group by dimMemberID having sum(AMT)>100 and sum(AMT)<200); -- having money BETWEEN 100 and 200 ); 不能直接用命名的列名money,要寫全函數,因為前面語句沒有出現money,所以為了避免報錯,之后盡量寫全函數

子查詢在from中做臨時表

2017年7月2日對每位會員累計購買金額進行分段

統計2017年7月2日每位會員的累計購買金額把第一步統計出來的數據作為臨時表,對統計出來的數據進行分組-- 1、統計2017年7月2日每位會員的累計購買金額SELECT dimMemberID ,SUM(AMT) as money FROM dw.fct_saleswhere dimDateID = '20170702'and dimMemberID <> 0group by dimMemberID ;-- 2、把第一步統計出來的數據作為臨時表,對統計出來的數據進行分段SELECT dimMemberID ,money ,case when money <100 then 'D' when money >=100 and money <500 then 'C' when money >=500 and money <1000 then 'B' when money >=1000 then 'A' else '其它' end as type1FROM (SELECT dimMemberID /*臨時表可以生成多個字段,并不是每個字段都需要用也行*/ ,SUM(AMT) as money FROM dw.fct_sales where dimDateID = '20170702' and dimMemberID <> 0 group by dimMemberID) as sn; /*子查詢在from后面做臨時表來用,必須給這個子查詢生成的臨時表取一個表的別名,否則會報錯*/

子查詢在select作為一個字段來返回

2017年7月2日計算每個會員購買金額,以及每個會員購買金額占總體金額的比

2017年7月2日每個會員購買金額總體金額合并兩個表

注意:在合并時where的條件要寫全,不要遺漏,不然容易出現邏輯錯誤

-- 1、2017年7月2日每個會員購買金額SELECT dimMemberID ,SUM(AMT) as moneyFROM dw.fct_saleswhere dimDateID = '20170702'and dimMemberID <>0 /*去除非會員,即 dimMemberID 為 0 的數據*/group by dimMemberID ;-- 2、總體金額SELECT SUM(AMT) FROM dw.fct_saleswhere dimDateID = '20170702';-- 3、合并兩個表 注意在合并時where的條件要寫全,不要遺漏,不然容易出現邏輯錯誤SELECT dimMemberID ,SUM(AMT) as money ,(SELECT SUM(AMT)/*統計總金額*/FROM dw.fct_saleswhere dimDateID = '20170702'and dimMemberID<>0) as total_money ,CONCAT( /*加上%號*/ ROUND( /*四舍五入保留4位小數,帶%一定要思考保留小數位數*/ SUM(AMT)/(SELECT SUM(AMT) FROM dw.fct_sales where dimDateID = '20170702' and dimMemberID<>0),4)*100,'%')as member_rate /*合并表,統計占比*/FROM dw.fct_saleswhere dimDateID = '20170702'and dimMemberID <>0 /*去除非會員,即 dimMemberID 為 0 的數據*/group by dimMemberID ;

到此這篇關于關于Mysql子查詢的三個應用場景的文章就介紹到這了,更多相關Mysql子查詢應用場景內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 高清在线观看自拍视频 | 99在线小视频 | 自拍国内 | 黄色成人毛片 | 久久精品国产午夜伦班片 | 精品久久久久久久 | 在线观看视频99 | 国产精品欧美一区二区在线看 | 在线观看视频一区 | 精品视频一区二区三区在线观看 | 香蕉香蕉国产片一级一级毛片 | 成人a视频 | 成人免费福利网站在线看 | 国产a一级毛片含羞草传媒 国产a自拍 | 国产精品久久久久久久久久日本 | 欧美成人专区 | 欧美第一页草草影院浮力 | 亚洲综合在线另类色区奇米 | 在线播放免费播放av片 | 日本vs欧美一区二区三区 | 免费特黄一区二区三区视频一 | 国产精品久久久久久久久 | 久爱免费观看在线网站 | 久草视频免费在线看 | 国产福利三区 | 久草不卡视频 | 亚洲成人在线播放视频 | 欧美粗又大gay69视频 | 欧美人成在线观看网站高清 | 香港一级特黄高清免费 | 国产精品免费一级在线观看 | 亚洲影视一区二区 | 欧美一级毛片免费看视频 | 成人免费网站视频www | 国产夫妇精品自在线 | xxxwww在线播放 | 亚洲综合日韩欧美一区二区三 | 日韩欧美视频一区二区三区 | 精品xxxxxbbbb欧美中文 | 久久国产精品岛国搬运工 | 久久久久琪琪去精品色村长 |