SQL - UNION ALL

 
Vista:

UNION ALL

Publicado por reki12 (3 intervenciones) el 05/09/2014 17:08:06
estoy haciendo un union en la misma tabla es decir, quiero duplicar la consulta del select de la misma tabla pero me esta salio un error en management tool de sql que dice asi, lo quiero asi porque estoy haciendo un formato de factura por medio de crystal, y quiero que una hoja salgan dos frecibos media carta, ya el union all lo hice y se encuentra dentro del codigo, que aspecto estoy obviando?

Msg 104, Level 16, State 1, Procedure RepReciboPagoDATATECHT2, Line 206
ORDER BY items must appear in the select list if the statement contains a UNION, INTERSECT or EXCEPT operator.
Msg 104, Level 16, State 1, Procedure RepReciboPagoDATATECHT2, Line 214
ORDER BY items must appear in the select list if the statement contains a UNION, INTERSECT or EXCEPT operator.
-----

Basicamente la consulta seria algo asi:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
SELECT
 
		 e.cod_emp AS codemp1 ,
		 e.nombre_completo,
		(case
		when e.nac = 2 then 'E-'
		else 'V-'
		end  +
		e.ci)as ci,
		n.co_novedad_dia,n.co_novedad_hora,n.num_pres,n.num_contpres,n.num_vac,
		[dbo].[ObtenerFechaCadena] (r.fec_emis)as fec_emis,
		r.reci_num,
 
		n.comentario,
		isnull(n.monto,0)as monto,
		n.auxi_cha,
		n.auxi_num,
		n.tipo,
		isnull(dbo.GetValorCampo(dbo.GetCampo('A001'),e.cod_emp),0)as SueldoMensVar,
 
		c.co_conce,
		c.des_conce,
 
		b.co_ban,
		b.des_ban,
		e.cta_banc1,
		e.fecha_ing,
 
		d.des_depart,
		d.co_depart,
 
		co.co_cont,
		co.des_cont,
 
		gn.fec_ini,
		gn.fec_fin,
		ca.co_cargo,
		ca.des_cargo,
		dbo.GetMontoNetoPagarRecibo(r.reci_num)
FROM
		dbo.snrecibo as r
 
inner join dbo.snnomi as n
		on(r.reci_num = n.reci_num)
 
inner join dbo.snconcep as c
		on(c.co_conce = n.co_conce)
 
inner join dbo.snemple as e
		on(n.cod_emp = e.cod_emp)
 
inner join dbo.sncont as co
		on(co.co_cont = r.co_cont)
 
left join dbo.snbanco as b
		on(e.co_ban1 = b.co_ban)
 
inner join dbo.sndepart as d
		on(d.co_depart = r.co_depart)
 
inner join dbo.sngennomi as gn
		on(gn.co_cont = r.co_cont)AND(gn.fec_emis = r.fec_emis)
 
inner join dbo.sncargo as ca
		on(ca.co_cargo = e.co_cargo)
WHERE
		(co.tip_cont in (1,2,3))AND
		(n.tipo in (1,2,3))AND
		((@iReci_Num_d is null OR r.reci_num >= @iReci_Num_d) AND (@iReci_Num_h is null OR (@iReci_Num_d is null AND r.reci_num is null) OR r.reci_num <= @iReci_Num_h))AND
		((@sCod_Emp_d is null OR r.cod_emp >= @sCod_Emp_d) AND (@sCod_Emp_h is null OR (@sCod_Emp_d is null AND r.cod_emp is null) OR r.cod_emp <= @sCod_Emp_h))AND
		((@sdFec_Emis_d IS NULL OR r.fec_emis >= @sdFec_Emis_d) AND (@sdFec_Emis_h IS NULL OR (@sdFec_Emis_d IS NULL AND r.fec_emis IS NULL) OR r.fec_emis <= @sdFec_Emis_h)) AND
		(@sCo_Cont is null OR e.co_cont = @sCo_Cont) AND
		((@sCo_ContGen_d is null OR r.co_cont >= @sCo_ContGen_d) AND (@sCo_ContGen_h is null OR (@sCo_ContGen_d is null AND r.co_cont is null) OR r.co_cont <= @sCo_ContGen_h))AND
		(@sCo_Depart is null OR e.co_depart = @sCo_Depart) AND
		((@sCo_DepartGen_d is null OR r.co_depart >= @sCo_DepartGen_d) AND (@sCo_DepartGen_h is null OR (@sCo_DepartGen_d is null AND r.co_depart is null) OR r.co_depart <= @sCo_DepartGen_h))	AND
		((@sCo_Ubicacion_d is null OR e.co_ubicacion >= @sCo_Ubicacion_d) AND (@sCo_Ubicacion_h is null OR (@sCo_Ubicacion_d is null AND e.co_ubicacion is null) OR e.co_ubicacion <= @sCo_Ubicacion_h))
 
UNION ALL
 
SELECT
		e.cod_emp as codemp2,
		e.nombre_completo,
		(case
		when e.nac = 2 then 'E-'
		else 'V-'
		end  +
		e.ci)as ci,
		n.co_novedad_dia,n.co_novedad_hora,n.num_pres,n.num_contpres,n.num_vac,
		[dbo].[ObtenerFechaCadena] (r.fec_emis)as fec_emis,
		r.reci_num,
 
		n.comentario,
		isnull(n.monto,0)as monto,
		n.auxi_cha,
		n.auxi_num,
		n.tipo,
		isnull(dbo.GetValorCampo(dbo.GetCampo('A001'),e.cod_emp),0)as SueldoMensVar,
 
		c.co_conce,
		c.des_conce,
 
		b.co_ban,
		b.des_ban,
		e.cta_banc1,
		e.fecha_ing,
 
		d.des_depart,
		d.co_depart,
 
		co.co_cont,
		co.des_cont,
 
		gn.fec_ini,
		gn.fec_fin,
		ca.co_cargo,
		ca.des_cargo,
		dbo.GetMontoNetoPagarRecibo(r.reci_num)
FROM
		dbo.snrecibo as r
 
inner join dbo.snnomi as n
		on(r.reci_num = n.reci_num)
 
inner join dbo.snconcep as c
		on(c.co_conce = n.co_conce)
 
inner join dbo.snemple as e
		on(n.cod_emp = e.cod_emp)
 
inner join dbo.sncont as co
		on(co.co_cont = r.co_cont)
 
left join dbo.snbanco as b
		on(e.co_ban1 = b.co_ban)
 
inner join dbo.sndepart as d
		on(d.co_depart = r.co_depart)
 
inner join dbo.sngennomi as gn
		on(gn.co_cont = r.co_cont)AND(gn.fec_emis = r.fec_emis)
 
inner join dbo.sncargo as ca
		on(ca.co_cargo = e.co_cargo)
WHERE
		(co.tip_cont in (1,2,3))AND
		(n.tipo in (1,2,3))AND
		((@iReci_Num_d is null OR r.reci_num >= @iReci_Num_d) AND (@iReci_Num_h is null OR (@iReci_Num_d is null AND r.reci_num is null) OR r.reci_num <= @iReci_Num_h))AND
		((@sCod_Emp_d is null OR r.cod_emp >= @sCod_Emp_d) AND (@sCod_Emp_h is null OR (@sCod_Emp_d is null AND r.cod_emp is null) OR r.cod_emp <= @sCod_Emp_h))AND
		((@sdFec_Emis_d IS NULL OR r.fec_emis >= @sdFec_Emis_d) AND (@sdFec_Emis_h IS NULL OR (@sdFec_Emis_d IS NULL AND r.fec_emis IS NULL) OR r.fec_emis <= @sdFec_Emis_h)) AND
		(@sCo_Cont is null OR e.co_cont = @sCo_Cont) AND
		((@sCo_ContGen_d is null OR r.co_cont >= @sCo_ContGen_d) AND (@sCo_ContGen_h is null OR (@sCo_ContGen_d is null AND r.co_cont is null) OR r.co_cont <= @sCo_ContGen_h))AND
		(@sCo_Depart is null OR e.co_depart = @sCo_Depart) AND
		((@sCo_DepartGen_d is null OR r.co_depart >= @sCo_DepartGen_d) AND (@sCo_DepartGen_h is null OR (@sCo_DepartGen_d is null AND r.co_depart is null) OR r.co_depart <= @sCo_DepartGen_h))	AND
		((@sCo_Ubicacion_d is null OR e.co_ubicacion >= @sCo_Ubicacion_d) AND (@sCo_Ubicacion_h is null OR (@sCo_Ubicacion_d is null AND e.co_ubicacion is null) OR e.co_ubicacion <= @sCo_Ubicacion_h))
 
 
GROUP BY e.cod_emp,	c.co_conce, e.nombre_completo, e.nac, e.ci, n.co_novedad_dia,n.co_novedad_hora,n.num_pres,n.num_contpres,n.num_vac,
r.fec_emis,		r.reci_num,	n.comentario, n.monto,	n.auxi_cha,		n.auxi_num,		n.tipo,e.cod_emp,
			c.des_conce,		b.co_ban,		b.des_ban,		e.cta_banc1,		e.fecha_ing,
			d.des_depart,		d.co_depart,		co.co_cont,		co.des_cont,		gn.fec_ini,
			gn.fec_fin,		ca.co_cargo,			ca.des_cargo,		r.reci_num
ORDER BY
CASE @sDir
    WHEN 'DESC' THEN
    CASE @sCampOrderBy
			WHEN 'nombre_completo' THEN e.nombre_completo
			else  e.cod_emp
	END
	END
	DESC,
CASE @sDir
    WHEN 'ASC' THEN
	CASE @sCampOrderBy
			WHEN 'nombre_completo' THEN e.nombre_completo
			else  e.cod_emp
	END
	END
	ASC
 
 
END
 
set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder

UNION ALL

Publicado por reki (3 intervenciones) el 08/09/2014 15:07:54
como que no se entendio lo que plantee, quiero hacer un UNION ALL en la misma consulta como, con el mismo select y la misma tabla, es decir duplicar la consulta.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar