You are on page 1of 2

Usar APPLY

Pgina 1 de 2

Al usar este sitio acepta el uso de cookies para anlisis, contenido personalizado y publicidad.

Saber ms

Usar APPLY
SQL Server 2008 R2

Personas que lo han encontrado til: 1 de 1

El operador APPLY permite invocar una funcin con valores de tabla para cada fila devuelta por una expresin de tabla externa de una consulta. La funcin con valores
de tabla acta como la entrada derecha y la expresin de tabla externa como la entrada izquierda. La entrada derecha se evala para cada fila de la entrada izquierda
y las filas producidas se combinan en la salida final. La lista de columnas producidas por el operador APPLY corresponde al conjunto de columnas de la entrada
izquierda, seguido de la lista de columnas devueltas por la entrada derecha.
Nota
Para utilizar APPLY, el nivel de compatibilidad de la base de datos debe ser al menos 90.
Existen dos formas de APPLY: CROSS APPLY y OUTER APPLY. CROSS APPLY slo devuelve las filas de la tabla externa que producen un conjunto de resultados de la
funcin con valores de tabla. OUTER APPLY devuelve tanto las filas que producen un conjunto de resultados como las que no, con valores NULL en la columna
producida por la funcin con valores de tabla.
Considere, por ejemplo, las siguientes tablas, Employees y Departments:

Create Employees table and insert values.


CREATE TABLE Employees
(
empid
int
NOT NULL
,mgrid
int
NULL
,empname varchar(25) NOT NULL
,salary money
NOT NULL
CONSTRAINT PK_Employees PRIMARY KEY(empid)
);
GO
INSERT INTO Employees VALUES(1 , NULL, 'Nancy'
, $10000.00);
INSERT INTO Employees VALUES(2 , 1
, 'Andrew' , $5000.00);
INSERT INTO Employees VALUES(3 , 1
, 'Janet'
, $5000.00);
INSERT INTO Employees VALUES(4 , 1
, 'Margaret', $5000.00);
INSERT INTO Employees VALUES(5 , 2
, 'Steven' , $2500.00);
INSERT INTO Employees VALUES(6 , 2
, 'Michael' , $2500.00);
INSERT INTO Employees VALUES(7 , 3
, 'Robert' , $2500.00);
INSERT INTO Employees VALUES(8 , 3
, 'Laura'
, $2500.00);
INSERT INTO Employees VALUES(9 , 3
, 'Ann'
, $2500.00);
INSERT INTO Employees VALUES(10, 4
, 'Ina'
, $2500.00);
INSERT INTO Employees VALUES(11, 7
, 'David'
, $2000.00);
INSERT INTO Employees VALUES(12, 7
, 'Ron'
, $2000.00);
INSERT INTO Employees VALUES(13, 7
, 'Dan'
, $2000.00);
INSERT INTO Employees VALUES(14, 11 , 'James'
, $1500.00);
GO
Create Departments table and insert values.
CREATE TABLE Departments
(
deptid
INT NOT NULL PRIMARY KEY
,deptname VARCHAR(25) NOT NULL
,deptmgrid INT NULL REFERENCES Employees
);
GO
INSERT INTO Departments VALUES(1, 'HR',
2);
INSERT INTO Departments VALUES(2, 'Marketing',
7);
INSERT INTO Departments VALUES(3, 'Finance',
8);
INSERT INTO Departments VALUES(4, 'R&D',
9);
INSERT INTO Departments VALUES(5, 'Training',
4);
INSERT INTO Departments VALUES(6, 'Gardening', NULL);

La mayora de los departamentos de la tabla Departments tienen un Id. de administrador que corresponde a un empleado de la tabla Employees. La siguiente
funcin con valores de tabla acepta un Id. de empleado como argumento y devuelve el empleado con todos sus subordinados.

CREATE FUNCTION dbo.fn_getsubtree(@empid AS INT)


RETURNS @TREE TABLE
(
empid
INT NOT NULL
,empname VARCHAR(25) NOT NULL
,mgrid
INT NULL
,lvl
INT NOT NULL
)
AS
BEGIN
WITH Employees_Subtree(empid, empname, mgrid, lvl)
AS
(
Anchor Member (AM)

http://technet.microsoft.com/es-es/library/ms175156(v=sql.105).aspx

02/03/2014

Usar APPLY

Pgina 2 de 2

SELECT empid, empname, mgrid, 0


FROM Employees
WHERE empid = @empid
UNION all
Recursive Member (RM)
SELECT e.empid, e.empname, e.mgrid, es.lvl+1
FROM Employees AS e
JOIN Employees_Subtree AS es
ON e.mgrid = es.empid
)
INSERT INTO @TREE
SELECT * FROM Employees_Subtree;
RETURN
END
GO

Para que se devuelvan todos los subordinados de todos los niveles para el administrador de cada departamento, utilice la consulta siguiente.

SELECT D.deptid, D.deptname, D.deptmgrid


,ST.empid, ST.empname, ST.mgrid
FROM Departments AS D
CROSS APPLY fn_getsubtree(D.deptmgrid) AS ST;

El conjunto de resultados es el siguiente.

deptid

1
1
1
2
2
2
2
2
3
4
5
5

deptname

HR
HR
HR
Marketing
Marketing
Marketing
Marketing
Marketing
Finance
R&D
Training
Training

deptmgrid

2
2
2
7
7
7
7
7
8
9
4
4

empid

2
5
6
7
11
12
13
14
8
9
4
10

empname

Andrew
Steven
Michael
Robert
David
Ron
Dan
James
Laura
Ann
Margaret
Ina

mgrid

1
2
2
3
7
7
7
11
3
3
1
4

lvl

0
1
1
0
1
1
1
2
0
0
0
1

Observe que cada fila de la tabla Departments se duplica tantas veces como filas de fn_getsubtree se devuelven para el administrador del departamento.
Adems, el departamento Gardening no aparece en los resultados. Como este departamento no tiene administrador, fn_getsubtree devolvi un conjunto vaco. Si
se utiliza OUTER APPLY, el departamento Gardening tambin aparecer en el conjunto de resultados, con valores NULL en el campo deptmgrid y en los campos
devueltos por fn_getsubtree.

Vea tambin
Referencia
FROM (Transact-SQL)

Te ha resultado til?

No

Adiciones de comunidad
2014 Microsoft. Reservados todos los derechos.

http://technet.microsoft.com/es-es/library/ms175156(v=sql.105).aspx

02/03/2014

You might also like