SQL練習(xí)題-2

員工表結(jié)構(gòu):


部門表結(jié)構(gòu):

部門員工表結(jié)構(gòu):

部門經(jīng)理表結(jié)構(gòu):

薪資表結(jié)構(gòu):

1.獲取所有員工當(dāng)前的manager筷黔,如果當(dāng)前的manager是自己的話結(jié)果不顯示,當(dāng)前表示to_date='9999-01-01'嫉沽。結(jié)果第一列給出當(dāng)前員工的emp_no,第二列給出其manager對應(yīng)的manager_no史翘。

分析:join連接兩表番官,限制條件dept_no要相等备籽,而兩表emp_no不相等舶治,兩表to_date='9999-01-01'

select de.emp_no, dm.emp_no as manager_no from dept_emp as? de inner join dept_manager dm?

on de.dept_no=dm.dept_no?

where de.to_date='9999-01-01'?

and dm.to_date='9999-01-01'

?and de.emp_no<>dm.emp_no;

2.獲取所有部門中當(dāng)前員工薪水最高的相關(guān)信息,給出dept_no, emp_no以及其對應(yīng)的salary

分析:對部門group by分組,max()函數(shù)找到salary最大值车猬,限定條件to_date='9999-01-01'

select d.dept_no, s.emp_no,max(salary) from dept_emp d, salaries s?

where d.emp_no=s.emp_no?

and d.to_date=s.to_date?

and s.to_date='9999-01-01'?

group by d.dept_no;

3.從titles表獲取按照title進(jìn)行分組霉猛,每組個(gè)數(shù)大于等于2,給出title以及對應(yīng)的數(shù)目t珠闰。

titles表結(jié)構(gòu):

分析:group by分組惜浅,count() 函數(shù)記錄行數(shù),having過濾條件伏嗜。

select title,count(*) t from titles group by title having count(*)>=2;

4.從titles表獲取按照title進(jìn)行分組坛悉,每組個(gè)數(shù)大于等于2伐厌,給出title以及對應(yīng)的數(shù)目t。注意對于重復(fù)的emp_no進(jìn)行忽略裸影。

分析:要忽略重復(fù)的emp_no挣轨,先對title分組,然后count(distinct emp_no)可以統(tǒng)計(jì)同一title下不同員工的個(gè)數(shù)

select title,count(distinct emp_no) t from titles group by title having t>=2;

5.查找employees表所有emp_no為奇數(shù)空民,且last_name不為Mary的員工信息刃唐,并按照hire_date逆序排列

分析: 使用where過濾條件, 奇數(shù)判斷可用emp_no%2=1,

select * from employees where emp%2=1 and last_name<>Mary order by hire_date desc;

6.統(tǒng)計(jì)出當(dāng)前各個(gè)title類型對應(yīng)的員工當(dāng)前(to_date='9999-01-01')薪水對應(yīng)的平均工資羞迷。結(jié)果給出title以及平均工資avg界轩。

分析:聯(lián)合查詢,限定條件t.emp_no=s.emp_no衔瓮,限制當(dāng)前(9999-01-01)條件浊猾,對title進(jìn)行分組,avg()函數(shù)求平均值

select t.title, avg(salary) avg from titles t,salaries s?

where t.emp_no=s.emp_no?

and t.to_date=s.to_date?

and s.to_date='9999-01-01'?

group by t.title;?

7.獲取當(dāng)前(to_date='9999-01-01')薪水第二多的員工的emp_no以及其對應(yīng)的薪水salary

分析:要考慮到多人同一薪資的情況热鞍,對薪水分組降序排序葫慎,用limit m,n 查詢第二條記錄

select emp_no,salary from salaries where to_date='9999-01-01' and salary=(select salary from salaries group by salary order by salary desc limit1,1);

8.查找當(dāng)前薪水(to_date='9999-01-01')排名第二多的員工編號(hào)emp_no、薪水salary薇宠、last_name以及first_name

分析:max()函數(shù)找到第二高的薪水偷办,連接兩表,限制條件為e.emp_no=s.emp_no澄港,to_date='9999-01-01'

select e.emp_no,s.salary,e.last_name,e.first_name from employees e join salaries s?

on e.emp_no=s.emp_no and s.salary=

(select max(salary) from salaries? where salary <?

(select max(salary) from salaries where to_date='9999-01-01'01') and to_date='9999-01-01')?

and e.to_date='9999-01-01';

9.查找所有員工的last_name和first_name以及對應(yīng)的dept_name椒涯,也包括暫時(shí)沒有分配部門的員工

部門表結(jié)構(gòu):

分析:“員工表”、“部門員工表”和“部門表”回梧,用left join連接employees和dept_emp兩表废岂,再用left join連接departments表,最后得到想要的結(jié)果狱意。

select e.last_name,e.first_name,d.dept_name from employees e

left join dept_emp de on e.emp_no = de.emp_no

left join departments d on de.dept_no = d.dept_no;

10.查找員工編號(hào)emp_no為10001其自入職以來的薪水salary漲幅值growth

分析:分別找出該員工入職時(shí)的薪水及最后一次的薪水湖苞,然后做差,別名為growth

select (

(select salary from salaries where emp_no='10001' order by to_date desc limit 1)-

(select salary from salaries where emp_no='10001' order by to_date asc limit 1)

) as growth;

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末详囤,一起剝皮案震驚了整個(gè)濱河市财骨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌藏姐,老刑警劉巖蚓再,帶你破解...
    沈念sama閱讀 212,294評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異包各,居然都是意外死亡摘仅,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,493評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門问畅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來娃属,“玉大人六荒,你說我怎么就攤上這事》耍” “怎么了掏击?”我有些...
    開封第一講書人閱讀 157,790評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長秩铆。 經(jīng)常有香客問我砚亭,道長,這世上最難降的妖魔是什么殴玛? 我笑而不...
    開封第一講書人閱讀 56,595評(píng)論 1 284
  • 正文 為了忘掉前任捅膘,我火速辦了婚禮,結(jié)果婚禮上滚粟,老公的妹妹穿的比我還像新娘寻仗。我一直安慰自己,他們只是感情好凡壤,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,718評(píng)論 6 386
  • 文/花漫 我一把揭開白布署尤。 她就那樣靜靜地躺著,像睡著了一般亚侠。 火紅的嫁衣襯著肌膚如雪曹体。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,906評(píng)論 1 290
  • 那天硝烂,我揣著相機(jī)與錄音箕别,去河邊找鬼。 笑死钢坦,一個(gè)胖子當(dāng)著我的面吹牛究孕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播爹凹,決...
    沈念sama閱讀 39,053評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼厨诸,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了禾酱?” 一聲冷哼從身側(cè)響起微酬,我...
    開封第一講書人閱讀 37,797評(píng)論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎颤陶,沒想到半個(gè)月后颗管,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,250評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡滓走,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,570評(píng)論 2 327
  • 正文 我和宋清朗相戀三年垦江,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片搅方。...
    茶點(diǎn)故事閱讀 38,711評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡比吭,死狀恐怖绽族,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情衩藤,我是刑警寧澤吧慢,帶...
    沈念sama閱讀 34,388評(píng)論 4 332
  • 正文 年R本政府宣布,位于F島的核電站赏表,受9級(jí)特大地震影響检诗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜瓢剿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,018評(píng)論 3 316
  • 文/蒙蒙 一逢慌、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧跋选,春花似錦涕癣、人聲如沸哗蜈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,796評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽距潘。三九已至炼列,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間音比,已是汗流浹背俭尖。 一陣腳步聲響...
    開封第一講書人閱讀 32,023評(píng)論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留洞翩,地道東北人稽犁。 一個(gè)月前我還...
    沈念sama閱讀 46,461評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像骚亿,于是被迫代替她去往敵國和親已亥。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,595評(píng)論 2 350