資料庫SQL實踐59:獲取有獎金的員工相關資訊。
思路:
可以獎金可以通過btype*salary/10.0得到。注意要除以10.0,如果除以10的話,結果的小數位會被捨去。
select e.emp_no,e.first_name,e.last_name,eb.btype,s.salary,(eb.btype*s.salary/10.0) as bonus from
employees e inner join emp_bonus eb on e.emp_no=eb.emp_no
inner join salaries s on eb.emp_no=s.emp_no and s.to_date='9999-01-01';
相關推薦
資料庫SQL實踐59:獲取有獎金的員工相關資訊。
思路: 可以獎金可以通過btype*salary/10.0得到。注意要除以10.0,如果除以10的話,結果的小數位會被捨去。 select e.emp_no,e.first_name,e.last_name,eb.btype,s.salary,(eb.btype*s.salary/10.0)
資料庫SQL實踐11:獲取所有員工當前的manager
思想: 題目要求獲取所有員工當前的manager,如果當前的manager是自己的話結果不顯示,當前表示to_date='9999-01-01'。 結果第一列給出當前員工的emp_no,第二列給出其manager對應的manager_no。首先通過條件e.dept_no = m.dept_no找
資料庫SQL實踐10:獲取所有非manager的員工emp_no
思想: 題目要求獲取所有非manager的員工emp_no。首先通過子查詢找到部門經理的emp_no,然後通過條件where emp_no not in找出非manager的emp_no。 select emp_no from employees where emp_no not in (s
資料庫SQL實踐9:獲取所有部門當前manager的當前薪水情況
思想: 題目要求獲取所有部門當前manager的當前薪水情況,給出dept_no, emp_no以及salary,當前表示to_date='9999-01-01'。首先通過條件d.to_date = '9999-01-01'來找出部門當前manager,然後通過條件s.to_date = '99
資料庫SQL實踐18:獲取當前薪水第二多的員工的emp_no以及其對應的薪水salary,不準使用order by
思想: 題目要求查詢當前薪水(to_date='9999-01-01')排名第二多的員工編號emp_no、薪水salary、last_name以及first_name,不準使用order by。首先通過條件e.emp_no=s.emp_no將兩表內連線相連,然後通過條件to_date='9999
資料庫SQL實踐17:獲取當前薪水第二多的員工的emp_no以及其對應的薪水salary
思想: 題目要求獲取當前(to_date='9999-01-01')薪水第二多的員工的emp_no以及其對應的薪水salary。首先通過條件to_date = '9999-01-01'獲取當前薪水,其次通過條件order by salary desc limit 1,1找到薪水第二多的員工(前提
資料庫SQL實踐25:獲取員工其當前的薪水比其manager當前薪水還高的相關資訊
思想: 題目要求獲取員工其當前的薪水比其manager當前薪水還高的相關資訊,當前表示to_date='9999-01-01', 結果第一列給出員工的emp_no, 第二列給出其manager的manager_no, 第三列給出該員工當前的薪水emp_salary, 第四列給該員工對應的mana
資料庫SQL實踐24:獲取所有非manager員工當前的薪水情況
思想: 題目要求獲取所有非manager員工當前的薪水情況,給出dept_no、emp_no以及salary ,當前表示to_date='9999-01-01'。 首先通過條件d.to_date = '9999-01-01'將員工所在當前部門找出。 其次通過條件s.to_date = '
資料庫SQL實踐31:獲取select * from employees對應的執行計劃
思想: explain 命令可以檢視SQL執行計劃的資訊,可以作為日常優化SQL的工具。 explain select * from employees; 原文:https://blog.csdn.net/youzi_yun/article/details/80562116
資料庫SQL實踐8:找出所有員工當前薪水salary情況
思想: 題目要求找出所有員工當前薪水salary情況,對於相同的薪水只顯示一次,並按照逆序顯示。首先根據當前薪水的要求通過條件to_date = '9999-01-01'來達到目的,然後根據相同的薪水只顯示一次的要求通過條件distinct salary來達到目的,最後通過order by sa
資料庫SQL實踐27:給出每個員工每年薪水漲幅超過5000的員工編號emp_no
思想: 題目要求給出每個員工每年薪水漲幅超過5000的員工編號emp_no、薪水變更開始日期from_date以及薪水漲幅值salary_growth,並按照salary_growth逆序排列。 提示:在sqlite中獲取datetime時間對應的年份函式為strftime('%Y', to
資料庫SQL實踐13:從titles表獲取按照title進行分組
思想: 題目要求從titles表獲取按照title進行分組,每組個數大於等於2,給出title以及對應的數目t。首先通過條件group by title實現按照title分組,其次通過條件having t>=2實現每組個數大於等於2(其中t是count(*)即每組的個數)。 selec
資料庫SQL實踐14:從titles表獲取按照title進行分組,注意對於重複的emp_no進行忽略
思想: 題目要求從titles表獲取按照title進行分組,每組個數大於等於2,給出title以及對應的數目t。注意對於重複的emp_no進行忽略。首先通過條件group by title實現按照title進行分組,其次通過條件count(distinct emp_no)實現對重複的emp_no
資料庫SQL實踐29:使用join查詢方式找出沒有分類的電影id以及名稱
思想: 題目要求使用join查詢方式找出沒有分類的電影id以及名稱。 首先將表film和film_category進行左連線,即若film沒有category_id,則category_id=null 最後用where條件找出沒有category_id的film。 select f.
資料庫SQL實踐47:如何獲取emp_v和employees相同的資料
思路: 先找出emp_v中的emp_no,然後作為集合,判斷employees中的emp_no是否在這個集合中,若在則取出記錄。 select * from employees where emp_no in (select emp_no from emp_v); 由於檢視 emp_v
資料庫SQL實踐7:查詢薪水漲幅超過15次的員工號emp_no以及其對應的漲幅次數t
思想: 題目要求查詢薪水漲幅超過15次的員工號emp_no以及其對應的漲幅次數t。首先通過group by函式對emp_no進行分組,將同一個emp_no的記錄分為一組並通過count(*)計算這個emp_no組中一共有幾條記錄,最後通過having函式找出記錄數大於15的。 知識點:
資料庫SQL實踐6:查詢所有員工入職時候的薪水情況
思想: 題目查詢所有員工入職時候的薪水情況,給出emp_no以及salary, 並按照emp_no進行逆序。首先根據所有員工入職時候的薪水要求通過條件e.hire_date = s.from_date來找到剛入職時候的薪水,然後根據按照emp_no進行逆序要求通過order by e.emp_n
資料庫SQL實踐2:查詢入職員工時間排名倒數第三的員工所有資訊
思想: 題目要求查詢入職員工時間排名倒數第三的員工所有資訊。首先通過一個子查詢(select distinct hire_date from employees order by hire_date desc limit 2,1)查找出入職員工時間排名倒數第三的入職時間hire_dat
資料庫SQL實踐23: 對所有員工的薪水按照salary進行按照1-N的排名
思想: 題目要求對所有員工的當前(to_date='9999-01-01')薪水按照salary進行按照1-N的排名,相同salary並列且按照emp_no升序排列。 首先通過條件where s1.to_date='9999-01-01' and s2.to_date='9999-01-01
資料庫SQL實踐22:統計各個部門對應員工漲幅的次數總和
思想: 題目要求統計各個部門對應員工漲幅的次數總和,給出部門編碼dept_no、部門名稱dept_name以及次數sum。 首先通過條件departments as d inner join dept_emp as e on d.dept_no = e.dept_no將depart