Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 09-06-2005
Avatar de marceloalegre
[marceloalegre] marceloalegre is offline
Miembro Premium
 
Registrado: abr 2005
Ubicación: Mar del Plata - Argentina
Posts: 448
Poder: 20
marceloalegre Va por buen camino
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.-
Responder Con Cita
  #2  
Antiguo 10-06-2005
Avatar de Crandel
[Crandel] Crandel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Parana, Argentina
Posts: 1.475
Poder: 22
Crandel Va por buen camino
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.
__________________
[Crandel]
Responder Con Cita
  #3  
Antiguo 10-06-2005
Avatar de marceloalegre
[marceloalegre] marceloalegre is offline
Miembro Premium
 
Registrado: abr 2005
Ubicación: Mar del Plata - Argentina
Posts: 448
Poder: 20
marceloalegre Va por buen camino
??

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!
Responder Con Cita
  #4  
Antiguo 10-06-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 27
jachguate Va por buen camino
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.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #5  
Antiguo 10-06-2005
Avatar de marceloalegre
[marceloalegre] marceloalegre is offline
Miembro Premium
 
Registrado: abr 2005
Ubicación: Mar del Plata - Argentina
Posts: 448
Poder: 20
marceloalegre Va por buen camino
Excelente respuesta, Muchas Gracias.-
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


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


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
Copyright 1996-2007 Club Delphi