Bài giảng Truy vấn nâng cao

Bảng tạm

with tscv as (

 select manv, count(*) ts from phancong

 group by manv

)

select manv, tennv,

 (select ts from tscv where manv=nv.manv)

 / (select sum(ts) from tscv) AS xxx

from nhanvien nv

--------------------------------------------------

select manv, count(*)/(select sum(ts) from tscv)

from phancong

group by manv

 

Bài giảng Truy vấn nâng cao trang 1

Trang 1

Bài giảng Truy vấn nâng cao trang 2

Trang 2

Bài giảng Truy vấn nâng cao trang 3

Trang 3

Bài giảng Truy vấn nâng cao trang 4

Trang 4

Bài giảng Truy vấn nâng cao trang 5

Trang 5

Bài giảng Truy vấn nâng cao trang 6

Trang 6

Bài giảng Truy vấn nâng cao trang 7

Trang 7

Bài giảng Truy vấn nâng cao trang 8

Trang 8

Bài giảng Truy vấn nâng cao trang 9

Trang 9

Bài giảng Truy vấn nâng cao trang 10

Trang 10

pptx 10 trang xuanhieu 3960
Bạn đang xem tài liệu "Bài giảng Truy vấn nâng cao", để tải tài liệu gốc về máy hãy click vào nút Download ở trên

Tóm tắt nội dung tài liệu: Bài giảng Truy vấn nâng cao

Bài giảng Truy vấn nâng cao
TRUY VẤN NÂNG CAO 
Bảng tạm 
with tscv as ( 
	select manv, count(*) ts from phancong 
	 group by manv 
) 
select manv, tennv, 
	(select ts from tscv where manv=nv.manv) 
 	 / (select sum(ts) from tscv ) AS xxx 
from nhanvien nv 
-------------------------------------------------- 
select manv, count (*)/(select sum(ts) from tscv ) 
from phancong 
group by manv 
Truy vấn đệ quy 
create table quanhe_nhanvien ( manv char(5) primary key,tennv char(20 ), manvct char(5)) 
------------------------------- 
manv	tennv	manvct 
Nv001	A	null 
Nv002	B	null 
Nv003	C	Nv001 
Nv004	D	Nv001 
Nv005	E	Nv003 
Nv006	F	Nv005 
Truy vấn đệ quy 
with truy (manv,tennv,manvct,mucdo,cay,cayten) as ( 
	select	a.manv,a.tennv,a.manvct,1 as mucdo, 
	cast('' as varchar(max)) as cay, 
	cast('' as varchar(max)) as cayten 
	from	quanhe_nhanvien a 
	where	 a.manvct is null 
	union all 
	select	 
	b.manv,b.tennv,b.manvct, mucdo + 1 as mucdo, 
	( truy.cay + '\' + b.manvct) as cay, 
	 cayten + '\' + cast( truy.tennv as varchar(20)) 
	 	as cayten 
	from	quanhe_nhanvien b inner join truy 
	on truy.manv = b.manvct 
) 
select * from truy 
Truy vấn đệ quy 
with truy (manv,tennv,manvct,kq) as ( 
	select	a.manv,a.tennv,a.manvct, 
	cast('' as varchar(max)) as kq 
	from	quanhe_nhanvien a 
	where	a.manvct is null 
	union all 
	select	b.manv,b.tennv,b.manvct, 
	 	( truy.kq + '\' + b.manvct) as kq 
	from	quanhe_nhanvien b inner join truy 
	on truy.manv = b.manvct 
) 
select * from truy 
Truy vấn đệ quy (kết quả) 
Manv 
Tennv 
Manvct 
Mucdo 
cay 
cayten 
Nv001 
A 
null 
1 
Nv002 
B 
Null 
1 
Nv003 
C 
Nv001 
2 
\Nv001 
\A 
Nv004 
D 
Nv001 
2 
\Nv001 
\A 
Nv005 
E 
Nv003 
3 
\Nv001\Nv003 
\A\C 
Nv006 
F 
Nv005 
4 
\Nv001\Nv003\Nv005 
\A\C\E 
Truy vấn đệ quy 
with truy (manv,tennv,manvct,mucdo,cay,cayten) as ( 
	select	a.manv,a.tennv,a.manvct,1 as mucdo, 
	cast('' as varchar(max)) as cay, 
	cast('' as varchar(max)) as cayten 
	from	quanhe_nhanvien a 
	where	a.manvct = a.manv 
	union all 
	select	 
	 	b.manv,b.tennv,b.manvct,mucdo + 1 as mucdo, 
	(truy.cay + '\' + b.manvct) as cay, 
	cayten + '\' + cast(truy.tennv as varchar(20)) 
	as cayten 
	from	quanhe_nhanvien b inner join truy 
	on truy.manv = b.manvct 
	where 	b.manv != b.manvct 
) 
select * from truy 
Đây là trường hợp điều kiện dừng là mã nv cấp trên và mã nv đó giống nhau. 
Truy vấn chéo  (Pivot) 
create table baocaods 
(nam int, mahang char(5 ), sl int, daily char(5), 
 constraint kc_baocaods primary key (nam,mahang,daily)) 
--------------------------------------------------------- 
(1998,'G1',3,'D1') 
(1999,'G1',4,'D1') 
(1997,'G1',2,'D1') 
(1998,'G2',9,'D1') 
(1999,'G2',4,'D1') 
(1997,'G2',6,'D1') 
(1998,'G1',32,'D2') 
(1999,'G1',42,'D2') 
(1997,'G1',22,'D2') 
(1998,'G2',30,'D2') 
(1999,'G2',40,'D2') 
(1997,'G2',20,'D2 ') 
Truy vấn chéo (Pivot) 
select mahang,[1997],[1998],[1999] 
from (select mahang,sl,nam from baocaods) as a 
pivot (sum(sl) for nam in [ 1997],[1998],[1999])) as b 
------------------------------------------------------ 
[1997],[1998],[1999] : là các giá trị 
mahang,sl,nam : gồm đúng 3 cột gồm Header Row,Header column, Value. 
Mệnh đề From và Pivot phải đặt lại tên mới . 
------------------------------------------------------ 
Mahang 	 1997	1998	1999 
G1	 	24 	35	46 
G2	 	26 	39	 44 
Truy vấn  (Cross – outer apply) 
select * 
From nhanvien as nv cross apply 
	( select count(*) as ts from phancong as pc 
 	 where pc.manv = nv .manv 
	) as tongsoviec 
Làm lại truy vấn count cho từng manv 
(có thể thay câu count thành hàm tính toán cho ra Table) 
Select * 
from 	nhanvien as nv inner join 
	( select manv,count(*) ts from phancong 
	 group by manv) as tscv 
	On tscv.manv = nv.manv 

File đính kèm:

  • pptxbai_giang_truy_van_nang_cao.pptx