1、where型子查詢
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:空間域名、虛擬主機(jī)、營(yíng)銷(xiāo)軟件、網(wǎng)站建設(shè)、無(wú)為網(wǎng)站維護(hù)、網(wǎng)站推廣。
(把內(nèi)層查詢結(jié)果當(dāng)作外層查詢的比較條件)
#不用order by 來(lái)查詢最新的商品
select goods_id,goods_name from goods where goods_id = (select max(goods_id) from goods);
#取出每個(gè)欄目下最新的產(chǎn)品(goods_id唯一)
select cat_id,goods_id,goods_name from goods where goods_id in(select max(goods_id) from goods group by cat_id);
2、from型子查詢
(把內(nèi)層的查詢結(jié)果供外層再次查詢)
#用子查詢查出掛科兩門(mén)及以上的同學(xué)的平均成績(jī)
思路:
#先查出哪些同學(xué)掛科兩門(mén)以上
select name,count(*) as gk from stu where score 60 having gk =2;
#以上查詢結(jié)果,我們只要名字就可以了,所以再取一次名字
select name from (select name,count(*) as gk from stu having gk =2) as t;
#找出這些同學(xué)了,那么再計(jì)算他們的平均分
select name,avg(score) from stu where name in (select name from (select name,count(*) as gk from stu having gk =2) as t) group by name;
3、exists型子查詢
(把外層查詢結(jié)果拿到內(nèi)層,看內(nèi)層的查詢是否成立)
#查詢哪些欄目下有商品,欄目表category,商品表goods
select cat_id,cat_name from category where exists(select * from goods where goods.cat_id = category.cat_id);
select?a.user_id?as?user_id,username,id?from?table_1?a?right?outer?join?table_2?b?using(user_id);
或者
select?a.user_id?as?user_id,username,id?from?table_1?a?right?outer?join?table_2?b?on?a.user_id=b.user_id;
前提是 stu_info的name和stu_paper的name是能對(duì)應(yīng)起來(lái)的
select paper.teacher from stu_info info,stu_paper paper where info.name=paper.name and info.id=已知的id
兩張表如果是關(guān)聯(lián)表,比如第一個(gè)表的sid對(duì)應(yīng)第二個(gè)表的sid 用 select * from 表名1 a(a是表明的別名) left join 表名2 b on a.sid=b.sid ;
如果沒(méi)有關(guān)聯(lián) select * from 表1 ,表2