Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   Consulta Cast (https://www.clubdelphi.com/foros/showthread.php?t=22247)

marceloalegre 09-06-2005 22:05:55

Consulta Cast
 
No entiendo por que tengo que tener la consulta con cast para esta union de 2 joins... asi mi consulta anda correcta alguien me dijo que use cast...pero no se bien que estoy haciendo...
Código SQL [-]
 
select
EVENTOSAUDITABLES.FECHAHORA,
OPERADORES.APELLIDO||' '||OPERADORES.NOMBRE as OPERADOR,
EVENTOS.DESCRIPCION as EVENTO_real,
EVENTOSAUDITABLES.NOTA,
EVENTOSAUDITABLES.ideventoauditable,
cast(null as integer) as idticket,
cast(null as varchar(255)) as NROTICKET,
cast(null as float) as TOTALIMPUESTO1,
cast(null as float) as TOTALIMPUESTO2,
cast(null as float) as TOTAL,
cast(null as float) as TOTALTICKET
from
EVENTOSAUDITABLES
left outer join OPERADORES
on (EVENTOSAUDITABLES.IDOPERADOR = OPERADORES.IDOPERADOR),
EVENTOS
where
(EVENTOSAUDITABLES.IDEVENTO = EVENTOS.IDEVENTO) and
(EVENTOSAUDITABLES.fechahora >= :fecini) and
(EVENTOSAUDITABLES.fechahora <= :fecfin)
 
union
 
select
TICKETS.fechahoraapertura as FECHAHORA,
OPERADORES.APELLIDO||' '||OPERADORES.NOMBRE as OPERADOR,
cast(null as varchar(255)) as EVENTO_real,
cast(null as varchar(255)) as NOTA,
cast(null as integer) as ideventoauditable,
TICKETS."idTicket" as idticket,
TICKETS.NROTICKET,
TICKETS.TOTALIMPUESTO1,
TICKETS.TOTALIMPUESTO2,
TICKETS.TOTAL,
cast(TICKETS.TOTAL - TICKETS.TOTALIMPUESTO1 - TICKETS.TOTALIMPUESTO2 as float) as TOTALTICKET
from
TICKETS
left outer join OPERADORES
on (OPERADORES.IDOPERADOR = TICKETS.IDOPERADOR)
where
(TICKETS.fechahoraapertura >= :fecini) and
(TICKETS.fechahoraapertura <= :fecfin)
order by
1
que hacen los cast... ? porque si llamo los campos como debe ser no anda esto... gracias.-

Crandel 10-06-2005 01:55:20

1. Escribe de acuerdo a las normas de estilo con las etiquetas, porque asi el SQL es medio dificil de leer.

2. El cast te permite convertir un tipo de datos en otro.

3. La sentencia UNION sólo puede unir dos tablas o consultas que posean exactamente la misma estructura.

marceloalegre 10-06-2005 13:59:07

??
 
Como estas Amigo Crandel, en cuanto a la sentencia union.. creo que no es asi... o quizas estoy confundido; a que te refieres con la misma estructura? podrias ejemplificar?

Gracias!

jachguate 10-06-2005 17:19:52

Supongo que trabajas con interbase/firebird, y trataré de explicartelo yo.

Supongamos que una consulta devuelve las siguientes columnas:

Código:

  Codigo    ShortInt
  Nombre    VarChar(40)
  Apellidos  VarChar(40)
  Saldo      Double Precision

Para realizar la unión de esta con otra consulta, la segunda tiene que devolver el mismo número de columnas, en el mismo orden y con los mismos tipos de datos.

Si devolviera algo como:

Código:

  Codigo    Integer
  Nombre    VarChar(40)
  Apellidos  VarChar(40)
  Saldo      Float

Es necesario hacer un CAST a las columnas que difieren en el tipo de datos en alguna de las consultas para que el motor acepte la unión.

He visto este comportamiento principalmente en ib/fb. Hay otros motores que "promueven" automáticamente los tipos de datos, aplicando las conversiones internamente, siempre que estas sean posibles.

En el caso particular del uso de NULL:

Código SQL [-]
Select null NombreCampo
  from tabla;

Tambien en IB/FB, hay que aplicarle un CAST al tipo de dato que tendrá la columna en el resultado final de la unión, puesto que ib/fb se porta bastante tontin en este aspecto y no entiende que el null podria unirlo con una columna de cualquier otro tpo de datos.

Hasta luego.

;)

marceloalegre 10-06-2005 17:30:46

Excelente respuesta, Muchas Gracias.-


La franja horaria es GMT +2. Ahora son las 04:42:07.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi