Bai Thuc Hanh Oracle 4 Tuan Tunghuynh Bai1
-- ------------------- STUDENT: Tùng Huynh-- ------------------- CLASS: K7A-- ------------------- Lesson 3.-- Cau I: (Session -> New Session: SYSTEM)-- Tạo user và grant quyềncreate user may12tunghuynh IDENTIFIED by 12345;grant CONNECT to may12tunghuynh;grant RESOURCE to may12tunghuynh;grant create view to may12tunghuynh;-- Câu II: Đăng nhập vào user hr (Session -> New Session: HR)-- II.1. -- Hiển thị mô tả các bảng (Tên các trường, kiểu dữ liệu,...)-- COUNTRIES, DEPARTMENTS, EMPLOYEES, JOB_HISTORY, JOBS, LOCATIONS, REGIONS của hr.describe hr.employees;describe hr.countries;describe hr.departments;describe hr.job_history;describe hr.jobs;describe hr.locations;describe hr.regions;-- II.2. -- Grant quyền select trên các bảng COUNTRIES, DEPARTMENTS, EMPLOYEES, -- JOB_HISTORY, JOBS, LOCATIONS, REGIONS của hr cho user đã tạo ở câu Igrant select on countries to may12tunghuynh;grant select on departments to may12tunghuynh;grant select on employees to may12tunghuynh;grant select on job_history to may12tunghuynh;grant select on jobs to may12tunghuynh;grant SELECT on locations to may12tunghuynh;grant SELECT on regions to may12tunghuynh;-- Cau III: Đăng nhập vào user đã tạo ở câu I (Session -> New Session: MAY12TUNGHUYNH)SELECT * from hr.jobs-- III.1. -- Hiển thị đầy đủ các trường của các bảng COUNTRIES, DEPARTMENTS, -- EMPLOYEES, JOB_HISTORY, JOBS, LOCATIONS, REGIONS trong user hr.-- III.2. -- Hiển thị cột FIRST_NAME ghép với cột LAST_NAME cách nhau -- bằng một khoảng trống và đặt tên cột ghép này là FULL NAME.select hr.employees.first_name ||' ' || hr.employees.last_name as "Full name"from hr.employees-- III.3. -- Hiển thị tên đầy đủ của nhân viên, email, số điện thoại, -- tên công việc, ngày vào làm. Dữ liệu lấy về phải sắp xếp theo ngày vào làm giảm dần. -- Hiển thị ngày vào làm phải định dạng theo dd/mm/yyyy.select e.first_name ||' ' || e.last_name as "Full name" , e.email, e.phone_number, j.job_title, to_date(e.hire_date,'dd/mm/yyyy') as "Ngay vao lam"from hr.employees e, hr.job_history jh, hr.jobs jwhere jh.employee_id=e.employee_id and e.job_id=j.job_id and j.job_id=hr.jh.job_idORDER by e.hire_date desc-- III.4. -- Hiển thị tên các phòng ban, địa điểm đặt, thuộc nước nào, châu lục nàoselect d.department_name, lo.street_address, lo.city, co.country_name, re.region_namefrom hr.countries co, hr.locations lo, hr.regions re, hr.departments dwhere lo.location_id=d.location_id and co.country_id=lo.country_id and re.region_id=co.region_id-- III.5. -- SELECT * from hr.employees-- Hiển thị tên nhân viên, thuộc phòng ban, người quản lý. -- Nếu nhân viên không thuộc phòng ban nào thì in ra thông báo No department, -- nếu nhân viên không có người quản lý thì in ra thông báo No manager. -- Sắp xếp dữ liệu theo tên người quản lýselect e.first_name ||' ' || e.last_name as "Full name", nvl(d.department_name,'No Department') as Department, nvl(trim(m.first_name ||' ' || m.last_name),'No manager') as Manager-- nvl(string1,string2): Null VaLue: Ktra neu string1=null thi in ra string2 from hr.employees e, hr.departments d, hr.employees m -- Nguoi quan ly nam trong danh sach nhan vien cong tywhere e.department_id=d.department_id(+) and m.employee_id(+)=e.manager_idorder by e.first_name-- CHÚ THÍCH: 5.1.3. Mối liên kết cộng -- Mối liên kết cộng trả về cả các giá trị NULL trong biểu thức điều kiện. -- Dấu (+) để ở vế nào tính thêm các giá trị NULL ở vế đó. -- Một câu lệnh select chỉ đặt được 1 mối liên kết cộng, dấu (+) đặt ở bên phải column liên kết -- III.6.-- SELECT * from hr.jobs -- Hiển thị công việc có mức lương cao nhất. select hr.jobs.job_title, hr.jobs.max_salaryfrom hr.jobswhere hr.jobs.max_salary= (select max(hr.jobs.max_salary) from hr.jobs)-- Hiển thị công việc có mức lương thấp nhất. select hr.jobs.job_title, hr.jobs.min_salaryfrom hr.jobswhere hr.jobs.min_salary = (select min(hr.jobs.min_salary) from hr.jobs) -- Hiển thị công việc có mức lương thấp nhất nằm trong khoảng 4000 -> 6000. select hr.jobs.job_title, hr.jobs.min_salaryfrom hr.jobswhere hr.jobs.min_salary = (select min(hr.jobs.min_salary) from hr.jobs where hr.jobs.min_salary >=4000 and hr.jobs.min_salary <= 6000)-- III.7. -- Hiển thị công việc có mức lương nằm trong khoảng 4000 -> 10000select hr.jobs.job_title, hr.jobs.min_salary, hr.jobs.max_salaryfrom hr.jobswhere hr.jobs.min_salary >= 4000 and hr.jobs.max_salary <= 10000-- Hiển thị công việc có biên độ trả lương rộng nhấtselect hr.jobs.job_title, hr.jobs.min_salary, hr.jobs.max_salaryfrom hr.jobswhere hr.jobs.max_salary-hr.jobs.min_salary = (select max(hr.jobs.max_salary-hr.jobs.min_salary) from hr.jobs) -- III.8. -- Hiển thị trung bình mức lương tối thiểu, trung bình mức lương cao nhất, làm tròn đến 3 số sau dấu phẩy. select trunc(avg(hr.jobs.min_salary),3) as "AVG min", trunc(avg(hr.jobs.max_salary),3) as "AVG max"from hr.jobs-- Hiển thị những công việc có mức lương tối thiểu nhỏ hơn mức lương tối thiểu trung bìnhselect hr.jobs.job_title, hr.jobs.min_salaryfrom hr.jobswhere hr.jobs.min_salary < (select avg(hr.jobs.min_salary) from hr.jobs)-- Hiển thị những công việc có mức lương cao nhất lớn hơn mức lương trung bình cao nhấtselect hr.jobs.job_title, hr.jobs.max_salaryfrom hr.jobswhere hr.jobs.max_salary > (select avg(hr.jobs.max_salary) from hr.jobs)-- III.9. -- Hiển thị công việc và số người làm công việc đó.select hr.employees.job_id, hr.jobs.job_title, count(hr.employees.employee_id) as Sonhanvienfrom hr.jobs, hr.employeeswhere hr.jobs.job_id=hr.employees.job_idgroup by hr.employees.job_id, hr.jobs.job_title-- Hiển thị công việc có số người làm nhiều nhất.select * from (select hr.employees.job_id, hr.jobs.job_title, count(hr.employees.employee_id) as Sonhanvienfrom hr.jobs, hr.employeeswhere hr.jobs.job_id=hr.employees.job_idgroup by hr.employees.job_id, hr.jobs.job_titleorder by Sonhanvien desc) where rownum=1-- Hiển thị tên nhân viên làm công việc có số người làm nhiều nhất đóselect hr.employees.first_name||' '||hr.employees.last_name as "Ten nhan vien"from hr.employeeswhere hr.employees.job_id = ( select job_id from ( select hr.employees.job_id, hr.jobs.job_title, count(hr.employees.employee_id) as Sonhanvien from hr.jobs, hr.employees where hr.jobs.job_id=hr.employees.job_id group by hr.employees.job_id, hr.jobs.job_title order by Sonhanvien desc ) where rownum=1-- III.10. -- Hiển thị tên đầy đủ của nhân viên và số tiền thưởng, nếu không có tiền thưởng thì hiển thị thông báo “No Commission”. -- Đặt tên cột tiền thưởng là COMMselect hr.employees.first_name||' '||hr.employees.last_name as "Ten nhan vien", nvl(TO_CHAR(hr.employees.commission_pct),'No commission') as Commfrom hr.employeesorder by "Ten nhan vien"-- III.11. -- Thực hiện tăng 20% lương cho tất cả các nhân viên. -- Hiện thị ra màn hình tên nhân viên, cột lương cũ và cột lương mới với tên cột lương mới là New Salaryselect hr.employees.first_name||' '||hr.employees.last_name as "Ten nhan vien", hr.employees.salary, hr.employees.salary*0.2+hr.employees.salary as "New salary"from hr.employees-- III.12. -- Hiển thị tên đầy đủ của các nhân viên có ký tự thứ 3 trong first_name là A (ví dụ: BLAKE, CLARK).-- VD: Char, PHA,...SELECT hr.employees.first_name||' '||hr.employees.last_name as "Ten nhan vien"from hr.employeeswhere UPPER(hr.employees.first_name) like UPPER('__a%')-- III.13. -- Hiển thị tên đầy đủ và ngày vào công ty (HIREDATE) của các nhân viên vào công ty năm 1999, -- định dạng HIREDATE là dd/mm/yyyyselect hr.employees.first_name||' '||hr.employees.last_name as "Ten nhan vien", to_char(hr.employees.hire_date,'dd/mm/yyyy') as "Hire date"from hr.employeeswhere EXTRACT(year from hr.employees.hire_date )=1999-- Hoac: where to_char(hr.employees.hire_date,'yyyy')='1999';-- III.14. -- Hiển thị tên đầy đủ và ngày vào công ty (HIREDATE) của các nhân viên vào công ty sau nhân viên Austin (last_name). -- Dữ liệu được xắp xếp theo HIREDATE giảm dầnselect hr.employees.first_name||' '||hr.employees.last_name as "Ten nhan vien", to_date(hr.employees.hire_date,'dd/mm/yyyy') as "Hire date"FROM hr.employeeswhere hr.employees.hire_date > (select hr.employees.hire_date from hr.employees where UPPER(hr.employees.last_name) = upper('austin'))order by hr.employees.hire_date-- III.15. -- Hiển thị tên đầy đủ, độ dài tên đầy đủ của các nhân viên có tên (first_name) bắt đầu là J, A hoặc M. -- Định dạng tên sao cho ký tự đầu tiên là ký tự hoa, các ký tự còn lại là ký tự thường. -- Đặt tên cho các cột tương ứng là Name, Length Nameselect hr.employees.first_name||' '||hr.employees.last_name as "Name", length(hr.employees.first_name)+length(hr.employees.last_name)+1 as "Length name"from hr.employeeswhere hr.employees.first_name like 'J%' or hr.employees.first_name like 'A%' or hr.employees.first_name like 'M%'-- III.16. -- Hiển thị các dòng giá trị duy nhất của các chức danh (job_title) trong phòng ban (department_id) 30, -- kèm theo địa chỉ (đường và thành phố) của phòng banSELECT DISTINCT hr.jobs.job_title, hr.locations.street_address, hr.locations.cityfrom hr.locations, hr.jobs, hr.departments, hr.employeeswhere hr.departments.department_id=30 and hr.departments.location_id=hr.locations.location_id and hr.employees.department_id=hr.departments.department_id and hr.employees.job_id=hr.jobs.job_id-- III.17. -- Hiển thị tên và nghề nghiệp (JOB) của tất cả các nhân viên không có quản lý (MGR). select hr.employees.first_name||' '||hr.employees.last_name as "Name", hr.jobs.job_titlefrom hr.jobs, hr.employeeswhere hr.jobs.job_id=hr.employees.job_id and hr.employees.manager_id is null-- III.18. -- Hiển thị tên (ENAME), nghề nghiệp (JOB) và lương (SAL) -- của các nhân viên có nghề nghiệp là President hoặc Accountant -- và mức lương không bằng $1000, $9000. select hr.employees.first_name||' '||hr.employees.last_name as "Name", hr.jobs.job_title, hr.employees.salaryfrom hr.jobs, hr.employeeswhere (upper(hr.jobs.job_title) like UPPER('President') or upper(hr.jobs.job_title) like UPPER('Accountant')) and hr.employees.salary != 1000 and hr.employees.salary != 9000 and hr.employees.job_id=hr.jobs.job_id-- III.19. -- Hiển thị tên phòng ban (DNAME), địa chỉ (LOC), -- số nhân viên thuộc phòng ban và lương (SAL) trung bình -- của các nhân viên trong phòng ban. Đặt tên các cột tương ứng là dname, -- loc, Number of People và Salary. -- Làm tròn lương trung bình đến 2 chữ số thập phân---------- Trước tiên tạo 1 view để lấy ID phòng ban và số nhân viên, lương TB trong từng phòng ban đócreate view demasselect hr.employees.department_id as "ID", count(hr.employees.employee_id) as "NumPp", trunc(avg(hr.employees.salary),2) as "Salary"from hr.employeesgroup by hr.employees.department_id--select * from dem---------- Phần chínhselect hr.departments.department_name as "Dname", hr.locations.street_address||' '||hr.locations.city as "Loc", dem."NumPp" as "Number of People", dem."Salary"from hr.departments, hr.locations, demwhere hr.departments.department_id=dem.ID and hr.locations.location_id=hr.departments.location_id--------- Cách 2 không cần dùng view:select hr.departments.department_name as Dname, hr.locations.street_address||' - '||hr.locations.city as "Loc", A."Sum Em" as "Number of People",trunc(A."AVG SAL",2) as "Salary"from hr.departments,hr.locations,( select count(hr.employees.department_id) as "Sum Em", trunc(avg(hr.employees.salary),3) "AVG SAL", hr.employees.department_id as ID from hr.employees group by hr.employees.department_id) Awhere hr.departments.location_id=hr.locations.location_idand hr.departments.department_id=A.ID-- III.20. -- Tìm ngày thứ 6 đầu tiên cách 2 tháng so với ngày hiện tại, -- hiển thị ngày dưới dạng 09 February 1990.-- select sysdate from dualselect to_char(next_day(add_months(sysdate,2),'thứ sáu'),'dd month yyyy')as Dayfrom dual-- next_day(d,string): Bắt đâu từ ngày d tăng dần cho đến khi gặp ngày có day=string ('thứ sáu')-- add_month(d,int): Tăng ngày tháng d thêm int tháng (int có thể âm -> lùi tháng, dương -> tiến tháng)-- III.21.-- Hiển thị tên nhân viên, ngày vào công ty và ngày trong tuần (thứ) -- của ngày vào công ty (đặt tên cột là DAY). -- Sắp xếp kết quả trả về theo các ngày trong tuần, bắt đầu từ chủ nhật, thứ hai....select hr.employees.first_name||' '||hr.employees.last_name as "Ten nhan vien", hr.employees.hire_date, to_char(hr.employees.hire_date,'day') as Dayfrom hr.employeesorder by Day-- III.22. -- Hiển thị lương (SAL) cao nhất, thấp nhất, tổng lương -- và lương trung bình của tất cả các nhân viên. -- Đặt tên các cột tương ứng là Maximum, Minimum, Sum và Average. -- Làm tròn kết quả trả vềselect max(hr.employees.salary) as Maximum, min(hr.employees.salary) as Minimum, Sum(hr.employees.salary) as Sum, round(avg(hr.employees.salary),2) as Averagefrom hr.employees-- III.23. -- Hiển thị mức lương cao nhất, thấp nhất, -- tổng lương và lương trung bình cho mỗi loại nghề nghiệpselect hr.jobs.*, round((hr.jobs.min_salary+hr.jobs.max_salary)/2,2) as AVGfrom hr.jobs-----------------------select max(hr.employees.salary) as "Maximum", min(hr.employees.salary) as "Minimum", sum(hr.employees.salary) as "Sum", trunc(avg(hr.employees.salary),3) as "Average"from hr.employees group by hr.employees.job_id
Bạn đang đọc truyện trên: ZingTruyen.Store