Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 28-09-2006
Ana Tudela Ana Tudela is offline
Miembro
 
Registrado: jul 2004
Posts: 29
Poder: 0
Ana Tudela Va por buen camino
Minus

Hola,

me gustaría saber si hay una instrucción equivalente en Interbase al MINUS de Oracle.

Gracias.
Responder Con Cita
  #2  
Antiguo 28-09-2006
Avatar de AGAG4
AGAG4 AGAG4 is offline
Miembro
 
Registrado: ago 2004
Ubicación: Los Mochis, Sinaloa, México
Posts: 1.420
Poder: 21
AGAG4 Va por buen camino
Porque no dices que Hace el Minus de Oracle ????Toma el Valor Mínimo ????
Responder Con Cita
  #3  
Antiguo 28-09-2006
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
minus es de la familia de operaciones de conjuntos, haciendo una resta de estos. Digamos que es un "hermano" de la operación union..

Firebird no tiene un equivalente a minus, supongo que Interbase tampoco lo tiene, pero creo que es posible escribir una sola sentencia select que nos devuelva el mismo resultado que sería producto de un minus:

Código SQL [-]
select id_cliente from cliente where pais = 'GUATEMALA'
minus
select id_cliente from cliente where ciudad = 'MIXCO'
es el equivalente a:
Código SQL [-]
select id_cliente from cliente where pais = 'GUATEMALA' and ciudad != 'MIXCO';

Hay otras equivalencias para las que podemos valernos de una clausula not exists.

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
  #4  
Antiguo 28-09-2006
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.044
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Si es que en esta vida todo tiene solución... todo, minus lo que ya sabéis
Responder Con Cita
  #5  
Antiguo 28-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Uy. Pero entonces el minus éste se ve un poco bobo ¿no?
Responder Con Cita
  #6  
Antiguo 28-09-2006
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #7  
Antiguo 28-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Je, je, yo también estoy confundido. Es que no veo clara la necesidad de un operador no estandar que puede reemplazarse tan sencillamente por algo mucho más canónico.

// Saludos
Responder Con Cita
  #8  
Antiguo 28-09-2006
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Yo diría que es una característica interesante, porque permite escribir queries mas fáciles de entender. A ver si me explico:

A mi me resulta mas fácil de entender el significado de:

Código SQL [-]
select id_cliente from cliente_moroso
minus
select id_cliente from cliente_interno

suponiendo que ambas son vistas que se basan en tabla cliente, donde cliente_moroso tiene uno o varios joins a otras tablas para determinar si hay documentos pendientes de pago con cierto atrazo (de acuerdo a la configuración del sistema), mientras que cliente_interno tiene un encuentro con la tabla de empresas, donde se define el id de cliente que corresponde a cada una de ellas.

Aún cuando sea posible escribir una sentencia particular para este caso, resulta mucho mas sencillo de escribir y leer queryes, también mas flexible el uso de estos operadores (también hay un operador intersect )

Claro que cuando no contamos con ellos, tenemos que picar mas piedra, pero si podemos llegar a los mismos resultados.

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
  #9  
Antiguo 28-09-2006
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.044
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Pregunto: ¿pero en esta forma de trabajar con "minus" se hacen 2 selects?
Porque si es así, entonces es mejor la forma "estandar" de firebird que es un sólo select, imagino que será más rápido y eficiente
Responder Con Cita
  #10  
Antiguo 28-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Entiendo lo que dices y voy de acuerdo en que resulta más legible pero como dice Casimiro, ¿no es ineficiente?

Digamos, algo como lo que ejemplificas, supongo que también puede hacerse con una subconsulta NOT IN que tengo entendido es más lenta que un JOIN. Ese minus, ¿no es como una subconsulta?

// Saludos
Responder Con Cita
  #11  
Antiguo 28-09-2006
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Cita:
Empezado por roman
Entiendo lo que dices y voy de acuerdo en que resulta más legible pero como dice Casimiro, ¿no es ineficiente?
Desconozco el tema de otros motores, pero en el caso de Oracle, el analizador/optimizador hace maravillas, por lo que no llegarán a ejecutarse dos consultas, una que devuelva un millón de registros y otra 999,999, para hacer la resta y devolver solo uno al final.

Oracle está en capacidad de encontrar una ruta óptima para realizar la consulta. Lo importante, como ya he resaltado, es que es mas semantico, por llamarle de alguna forma.

Cita:
Empezado por roman
Digamos, algo como lo que ejemplificas, supongo que también puede hacerse con una subconsulta NOT IN que tengo entendido es más lenta que un JOIN. Ese minus, ¿no es como una subconsulta?
Muchos de los problemas que pueden resolverse con minus pueden resolverse con un not in o a veces dentro de un query sin ellos, por lo que no resulta "indispensable".

Sin embargo, si se da la opción de elegir, teniendo en cuenta que el motor sea capaz de procesarlo de manera optima, yo me quedo con los operadores sobre conjuntos.. (y muchos otros "analíticos" que tiene el oracle ese...)

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #12  
Antiguo 28-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Tomo tu palabra en lo que vale, o sea, mucho, así que doy por buena la explicación . Más que nada era curiosidad sobre estos operadores.

// Saludos
Responder Con Cita
  #13  
Antiguo 29-09-2006
Avatar de Paoti
Paoti Paoti is offline
Miembro
 
Registrado: may 2003
Ubicación: Monterrey. N.L., México
Posts: 612
Poder: 21
Paoti Va por buen camino
Desconozco si firebird soporta:


From T1 where (c1, c2, c3) not in (select a.c1, a.c2, a.c3 from t2 a)



en Oracle puedo usar minus de la siguiente manera.

Código SQL [-]
Select  c1, c2, c3 from tabla1
minus
Slect a.c1, a.c2, a.c3 from t2 a

que se em hace una maravilla



saludos
__________________
Estudia y anda en la calle.... que asi serás el doble de listo que los demás...

análisis de información
análisis y diseño de sistemas

Paoti Rios Reséndiz
Responder Con Cita
  #14  
Antiguo 29-09-2006
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Cita:
Empezado por Paoti
Desconozco si firebird soporta:
...
que se em hace una maravilla
¡Claro que es una maravilla!, y lamentablemente no está soportado de dicha manera en firebird.

Sin embargo, hasta ahora no he encontrado un "minus" que no pueda plantearse en terminos de firebird... aunque a veces es realmente complicado y requiere de mucho ingenio..

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
  #15  
Antiguo 29-09-2006
Avatar de Paoti
Paoti Paoti is offline
Miembro
 
Registrado: may 2003
Ubicación: Monterrey. N.L., México
Posts: 612
Poder: 21
Paoti Va por buen camino
Me encanta Firebird,



y nunca me he presentado con realizar intrucciones complicadas en firebird.


Y siempre hay que encontrar una solución jachguate.



Saludos.




les muestro el select que hice en oracle, para una insercción masiva:

Código SQL [-]
FROM m4_PRESUPUESTOS PRE
WHERE PRE.id_ejercicio = vEjer_Tes
AND
    (PRE.id_centro_costo, PRE.id_partida, PRE.id_programa, PRE.id_proyecto)
IN
    (select pt.id_centro_costo, pt.id_partida, pt.id_programa, pt.id_proyecto from m4_presupuestos pt
            where pt.id_ejercicio =  vEjer_Tes
      MINUS
    select p.id_centro_costo, p.id_partida, p.id_programa, p.id_proyecto from M4t_PRESUPUESTOS_GASTO p
            where p.id_ejercicio = vEjercicio and p.version = vVersion);
__________________
Estudia y anda en la calle.... que asi serás el doble de listo que los demás...

análisis de información
análisis y diseño de sistemas

Paoti Rios Reséndiz
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 00:01:23.


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