FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
En Consulta SQL seleccionar un campo de un conjunto, Segun criterio
Estimados Amigos:
Tengo dos tabla en firebird 2.5 con la siguiente estructura Código:
Tabla : EMPRESAS_STAR ID INTEGER NOT NULL, /* pk */ EMPRESAS_ID INTEGER NOT NULL, /* fk - CON TABLA EMPRESAS */ STAR_1 INTEGER DEFAULT 0, STAR_2 INTEGER DEFAULT 0, STAR_3 INTEGER DEFAULT 0, STAR_4 INTEGER DEFAULT 0, STAR_5 INTEGER DEFAULT 0 Tabla : EMPRESAS ID INTEGER NOT NULL, /* pk */ CUIT STR11 NOT NULL NOMBRE STR100 NOT NULL, DIRECCION STR100 , POSTAL STR10, TELEFONO_1 STR20, los campos STAR_x, tienen dos posibles valores 0 y 1, dependiendo de la calificacion dada, obviamente solo uno de los cinco, puede estar en 1. Deseo hacer una consulta de los datos de las empresas, donde ademas aparezca la calificacion de la misma, algo como: Código:
select empresas.id, empresas.cuit, empresas.nombre, empresas.direccion, empresas.postal, empresas.telefono_1, empresas_star.id, empresas_star.star_x from empresas_star inner join empresas on (empresas_star.empresas_id = empresas.id Gracias por su tiempo.
__________________
Adrián Murúa. |
#2
|
||||
|
||||
Investigando un poco lo resolví de la siguiente manera:
he creado un procedimiento almacenado que me devuelve el ID de la Empresa y su calificación dependiendo siempre de cual de los campos star_x esta en 1. el código en el IBExpert es el siguiente : de esta manera tengo las calificaciones de las empresas, asociadas por el ID, luego hago una consulta, donde mediante un INNER JOIN con el procedimiento almacenado(utilizado como una tabla mas ), tengo los datos de las empresas y la calificacion de cada una de ellas, la consulta es la siguiente:
No se si es la forma correcta de resolver el problema, quizas exista alguna mas simple . Espero que le sirva a alguien mas ... Saludos.
__________________
Adrián Murúa. |
#3
|
|||
|
|||
Hola
Esta bien utilizar procedimientos cuando es necesario pero no cuando con una simple select lo puedes resolver para ello a partir de firbird 2.0 existe el case
Creo no haber hecho ningun error de sintaxis (pero la idea es esa) Saludos |
#4
|
||||
|
||||
Cita:
__________________
Adrián Murúa. |
#5
|
||||
|
||||
He probado la clausula CASE - WHEN , pero aparentemente funciona en el caso de que un campo tenga varios valores, en el caso del ejemplo seria si la tabla tuviera un campo STAR el cual tomara valores de 1 a 5, en el caso expuesto, no funciona ya que tendria que hacer un CASE para cada campo STAR_X, lo que lo convierte en un IF para validar si el campo tiene un valor 0 ó 1.
Asi que vuelvo a la opcion del procedimiento almacenado. Gracias por su tiempo
__________________
Adrián Murúa. |
#6
|
|||
|
|||
Creo es más aceptable la cuestion del CASE, claro ahi para que no te retorne 5 en else pondrías 0, otra forma cre es la siguiente.
select empresas.id, empresas.cuit, empresas.nombre, empresas.direccion, empresas.postal, empresas.telefono_1, (empresas_star.star_1 * 1 + empresas_star.star_2* 2 + empresas_star.star_3 * 3 + empresas_star.star_4 * 4) Calificacion from empresas_star innerjoin empresas on (empresas_star.empresas_id = empresas.id esto siempre y cuando acepte star_x solo 0 o 1 como valore asi 0*1 = 0, 1*2 = 2 .... |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Generar Codigo Por Letras Segun Criterio | Lenny | Varios | 5 | 31-12-2010 03:29:18 |
sumar registros segun un criterio rave report | carlos munera | Impresión | 0 | 26-11-2009 05:03:50 |
Incrementar campo según el valor de otro | subzero | Firebird e Interbase | 3 | 06-08-2008 21:41:52 |
Repetir registro segun valor de un campo | yusnerqui | SQL | 2 | 13-03-2005 02:14:40 |
impresion de campo segun el dato | marcelofabiani | Impresión | 1 | 02-10-2003 23:17:49 |
|