FTP | CCD | Buscar | Trucos | Trabajo | Foros |
#1
|
|||
|
|||
Minus
Hola,
me gustaría saber si hay una instrucción equivalente en Interbase al MINUS de Oracle. Gracias. |
#2
|
||||
|
||||
Porque no dices que Hace el Minus de Oracle ????Toma el Valor Mínimo ????
|
#3
|
||||
|
||||
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: es el equivalente a:
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 |
#4
|
||||
|
||||
Si es que en esta vida todo tiene solución... todo, minus lo que ya sabéis
|
#5
|
||||
|
||||
Uy. Pero entonces el minus éste se ve un poco bobo ¿no?
|
#6
|
||||
|
||||
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#7
|
||||
|
||||
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 |
#8
|
||||
|
||||
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:
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 |
#9
|
||||
|
||||
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 |
#10
|
||||
|
||||
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 |
#11
|
||||
|
||||
Cita:
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:
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 |
#12
|
||||
|
||||
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 |
#13
|
||||
|
||||
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.
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 |
#14
|
||||
|
||||
Cita:
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 |
#15
|
||||
|
||||
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:
__________________
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 |
|
|
|