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 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223
|
SELECT
tgTaller.descrip as Atelier,
tgEmpresa.razon as Société,
ttMecanico.Nombre as Mécanicien,
(SELECT Descrip FROM tyUsuarioEquipo
WHERE tyUsuarioEquipo.Emp = ttOTFac.Emp AND
tyUsuarioEquipo.Grupo = ttMecanico.PresenciaGrupo AND
tyUsuarioEquipo.Equipo = ttMecanico.PresenciaEquipo
) AS descrip_equipo,
ttOTCab.NumInterno,
ttOTCab.AnoOT,
ttOTCab.NumOT,
ttOTAsigTiempoFac.Intervencion,
substring(ttOTIntervencion.Descrip,1,100) AS TextoIntervencion,
ttSeccion.Descrip,
(ROUND(
COALESCE ((SELECT SUM(TiempoPasado)
FROM ttOTFichado
WHERE ttOTFichado.Emp = ttOTFac.Emp AND
ttOTFichado.NumInterno = ttOTFac.NumInterno AND
ttOTFichado.Mecanico = ttOTAsigTiempoFac.Mecanico AND
ttOTFichado.Intervencion = ttOTCargoInt.NumIntIntervencion AND
(NOT (ttOTFichado.RepartoPendiente = 0 AND ttOTFichado.FichajeContraOT > 0) or ttOTFichado.RepartoPendiente IS NULL) AND
ttOTFichado.TiempoPasado > 0)
,0) *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100,2)
) as "Temps passé",
(CASE ttOTAsigTiempoFac.Mecanico
WHEN '*' THEN
CASE ttOTAsigTiempoFac.RepartoMecanico
WHEN 100 THEN
ROUND ( ttOTAsigTiempoFac.TiempoFacturado *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 4)
ELSE 0
END
ELSE
ROUND (ttOTAsigTiempoFac.TiempoMecanico *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 4)
END
) as "Temps Facturé" ,
((CASE ttOTAsigTiempoFac.Mecanico
WHEN '*' THEN
CASE ttOTAsigTiempoFac.RepartoMecanico
WHEN 100 THEN
ROUND ( ttOTAsigTiempoFac.TiempoFacturado *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 4)
ELSE 0
END
ELSE
ROUND (ttOTAsigTiempoFac.TiempoMecanico *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 4)
END
) - (ROUND(
COALESCE ((SELECT SUM(TiempoPasado)
FROM ttOTFichado
WHERE ttOTFichado.Emp = ttOTFac.Emp AND
ttOTFichado.NumInterno = ttOTFac.NumInterno AND
ttOTFichado.Mecanico = ttOTAsigTiempoFac.Mecanico AND
ttOTFichado.Intervencion = ttOTCargoInt.NumIntIntervencion AND
(NOT (ttOTFichado.RepartoPendiente = 0 AND ttOTFichado.FichajeContraOT > 0) or ttOTFichado.RepartoPendiente IS NULL) AND
ttOTFichado.TiempoPasado > 0)
,0) *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100,2)
))as Ecart,
(((CASE ttOTAsigTiempoFac.Mecanico
WHEN '*' THEN
CASE ttOTAsigTiempoFac.RepartoMecanico
WHEN 100 THEN
ROUND ( ttOTAsigTiempoFac.TiempoFacturado *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 4)
ELSE 0
END
ELSE
ROUND (ttOTAsigTiempoFac.TiempoMecanico *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 4)
END
) - (ROUND(
COALESCE ((SELECT SUM(TiempoPasado)
FROM ttOTFichado
WHERE ttOTFichado.Emp = ttOTFac.Emp AND
ttOTFichado.NumInterno = ttOTFac.NumInterno AND
ttOTFichado.Mecanico = ttOTAsigTiempoFac.Mecanico AND
ttOTFichado.Intervencion = ttOTCargoInt.NumIntIntervencion AND
(NOT (ttOTFichado.RepartoPendiente = 0 AND ttOTFichado.FichajeContraOT > 0) or ttOTFichado.RepartoPendiente IS NULL) AND
ttOTFichado.TiempoPasado > 0)
,0) *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100,2)
))/ NULLIF((ROUND(
COALESCE ((SELECT SUM(TiempoPasado)
FROM ttOTFichado
WHERE ttOTFichado.Emp = ttOTFac.Emp AND
ttOTFichado.NumInterno = ttOTFac.NumInterno AND
ttOTFichado.Mecanico = ttOTAsigTiempoFac.Mecanico AND
ttOTFichado.Intervencion = ttOTCargoInt.NumIntIntervencion AND
(NOT (ttOTFichado.RepartoPendiente = 0 AND ttOTFichado.FichajeContraOT > 0) or ttOTFichado.RepartoPendiente IS NULL) AND
ttOTFichado.TiempoPasado > 0)
,0) *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100,2)
),0.00))as TEST,
(CASE ttOTAsigTiempoFac.Mecanico
WHEN '*' THEN
CASE ttOTAsigTiempoFac.RepartoMecanico
WHEN 100 THEN
ROUND (ttOTAsigTiempoFac.TiempoFacturado *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 2)
ELSE 0
END
ELSE
ROUND (ttOTAsigTiempoFac.TiempoFacturado *
case ttOTCargoInt.TipoReparto
when 0 then ttOTCargoInt.Reparto
when 1 then ttOTCargoInt.RepartoMO
end *
(1 - 2 * ttOTFac.Abono) / 100, 2)
END
) as TiempoFacturado,
ttCodigoTiempo.Descrip,
ttOTAsigTiempoFac.RepartoMecanico,
ttOTCargoInt.Reparto,
dbo.fn_icardms_convertdatetime('1-2-2011 0:0:0.000') as ad_desde,
dbo.fn_icardms_convertdatetime('28-2-2011 23:59:59.000') as ad_hasta
FROM
ttOTFac,
ttOTCab
LEFT OUTER JOIN tgCortesia ON tgCortesia.Codigo = ttOTCab.Cortesia,
ttOTIntervencion
LEFT OUTER JOIN ttSeccion ON ttSeccion.Seccion = ttOTIntervencion.Seccion,
ttOTCargo
LEFT OUTER JOIN ttCodigoTiempo ON ttCodigoTiempo.Codigo = ttOTCargo.CodigoTiempo,
ttOTCargoInt,
ttOTAsigTiempoFac
LEFT OUTER JOIN ttMecanico ON ttOTAsigTiempoFac.Emp = ttMecanico.Emp AND
ttOTAsigTiempoFac.Mecanico = ttMecanico.Mecanico,
tgCliente
LEFT OUTER JOIN tgCortesia tgCortesiaCargo ON tgCortesiaCargo.Codigo = tgCliente.Cortesia,
tgEmpresa,
tgTaller
WHERE
ttOTFac.NumInterno = ttOTCab.NumInterno AND
ttOTFac.FechaFactura BETWEEN '1-2-2011 0:0:0.000' AND '28-2-2011 23:59:59.000' AND
ttOTCab.Emp = ttOTFac.Emp AND
ttOTCargoInt.Emp = ttOTFac.Emp AND
ttOTCargoInt.NumIntOT = ttOTFac.NumInterno AND
ttOTCargoInt.NumIntCargo = ttOTFac.NumIntCargo AND
ttOTCargoInt.Gratuita = 0 AND
ttOTAsigTiempoFac.Emp = ttOTCab.Emp AND
ttOTAsigTiempoFac.NumIntOT = ttOTCab.NumInterno AND
ttOTAsigTiempoFac.Intervencion = ttOTCargoInt.NumIntIntervencion AND
ttOTIntervencion.Emp = ttOTFac.Emp AND
ttOTIntervencion.NumInterno = ttOTFac.NumInterno AND
ttOTIntervencion.Intervencion = ttOTAsigTiempoFac.Intervencion AND
ttOTCargo.Emp = ttOTFac.Emp AND
ttOTCargo.NumInterno = ttOTFac.NumInterno AND
ttOTCargo.Cargo = ttOTFac.NumIntCargo AND
tgEmpresa.Emp = ttOTCab.Emp AND
tgTaller.Emp = ttOTCab.Emp AND
tgTaller.Taller = ttOTCab.Taller AND
tgCliente.Codigo = ttOTCargo.Cliente AND
(ttOTAsigTiempoFac.TiempoFacturado <> 0 OR
(SELECT SUM(TiempoPasado)
FROM ttOTFichado
WHERE ttOTFichado.Emp = ttOTFac.Emp AND
ttOTFichado.NumInterno = ttOTFac.NumInterno AND
ttOTFichado.Mecanico = ttOTAsigTiempoFac.Mecanico AND
ttOTFichado.Intervencion = ttOTCargoInt.NumIntIntervencion AND
(NOT (ttOTFichado.RepartoPendiente = 0 AND ttOTFichado.FichajeContraOT > 0) or ttOTFichado.RepartoPendiente IS NULL) AND
ttOTFichado.TiempoPasado > 0) <> 0) |
Partager