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 23-11-2012
Avatar de newtron
[newtron] newtron is offline
Membrillo Premium
 
Registrado: abr 2007
Ubicación: Motril, Granada
Posts: 3.478
Poder: 21
newtron Va camino a la fama
Consulta SQL

Hola a tod@s

Tengo una consulta SQL que es sencilla pero no se la traga accediendo a una base de datos remota Progress mediante ODBC.

Tengo dos tablas con los siguientes campos (versión resumida):

TL_TARIFAS

cod_tar
nom_tar

TL_PRECIOS

codtl_art
cod_tar


y quiero sacar con una instrucción sql desde la tabla TL_PRECIOS los campos codtl_art,cod_tar y nom_tar que está en la tabla TL_TARIFAS

de forma habitual yo pongo:

Código SQL [-]
SELECT codtl_art,cod_tar,(SELECT nom_tar FROM TL_TARIFAS where TL_PRECIOS.cod_tar=TL_TARIFAS.cod_tar) from TL_PRECIOS where...

pero me da error de sintaxis

¿Me podríais dar otras formas de hacer lo mismo? porque yo soy algo negado para el SQL... bueno... y para todo lo demás también.

Gracias y un saludo
__________________
Be water my friend.

Última edición por Casimiro Notevi fecha: 23-11-2012 a las 20:10:28.
Responder Con Cita
  #2  
Antiguo 23-11-2012
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola newtron.

A ver amigo, si te he entendido bién, creo que sería
Código SQL [-]
SELECT P.CODTL_ART, T.COD_TAR, T.NOM_TAR 
FROM TL_TARIFAS T, TL_PRECIOS P
WHERE T.COD_TAR = P.COD_TAR

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #3  
Antiguo 23-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.096
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Hombre, amigo newtron, te doy un tirón de orejas, ¿dónde están los títulos descriptivos?, ¿dónde están las etiquetas al código?...

A ver, le doy una revisión y ahora miro esa sql...


EDITO: bueno, ya contestó ecfisa
Responder Con Cita
  #4  
Antiguo 23-11-2012
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por Casimiro Notevi Ver Mensaje
EDITO: bueno, ya contestó ecfisa
Si, pero no viene mál que le pongas los puntos al desorejado ese...

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #5  
Antiguo 24-11-2012
Avatar de newtron
[newtron] newtron is offline
Membrillo Premium
 
Registrado: abr 2007
Ubicación: Motril, Granada
Posts: 3.478
Poder: 21
newtron Va camino a la fama
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Hombre, amigo newtron, te doy un tirón de orejas, ¿dónde están los títulos descriptivos?, ¿dónde están las etiquetas al código?...
Pandilla de tiquismiquis.... por una puñetera línea.....

Gracias, voy a hacer alguna prueba.
__________________
Be water my friend.
Responder Con Cita
  #6  
Antiguo 24-11-2012
Avatar de newtron
[newtron] newtron is offline
Membrillo Premium
 
Registrado: abr 2007
Ubicación: Motril, Granada
Posts: 3.478
Poder: 21
newtron Va camino a la fama
A ver....

Creo que no se me ha entendido bien, voy a intentar desarrollar y ampliar un poco el asunto porque el enlace a la tabla TL_TARIFAS es solo para sacar de ahí el nombre de la tarifa y el resto es un select normal filtrado por otro campo, por ejemplo una referencia de artículo.

Ejemplo

Registros en tabla TL_TARIFAS

Código SQL [-]
Cod_Tar   Nom_Tar
1              TARIFA 2010
2              TARIFA 2011
3              TARIFA 2012

Registros en tabla TL_PRECIOS

Código SQL [-]
Cod_tlart     Cod_tar
001              1
001              2
001              3
002              1
002              2

y lo que pretendo es que con la instrucción SQL me aparezcan los registros de la tabla TL_PRECIOS de un determinado artículo y con su nombre de tarifa, es decir:

Código SQL [-]
Cod_tlart   Cod_tar   Nom_tar
001             1            TARIFA 2010
001             2            TARIFA 2011
001             3            TARIFA 2012

¿"mesentiende" ya?

Gracias y un saludo
__________________
Be water my friend.
Responder Con Cita
  #7  
Antiguo 24-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.096
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
El código que ha puesto ecfisa hace exactamente eso que pides.
Puedes hacerlo también de esta otra forma, el resultado es el mismo:
Código SQL [-]
select pre.cod_tlart, pre.cod_tar, tar.nom_tar
from tb_precios pre
inner join tl_tarifas tar on (tar.cod_tar=pre.cod_tar)
Ahora bien, si lo que quieres es que no salgan repetidos, o algo "especial".
Responder Con Cita
  #8  
Antiguo 24-11-2012
Avatar de newtron
[newtron] newtron is offline
Membrillo Premium
 
Registrado: abr 2007
Ubicación: Motril, Granada
Posts: 3.478
Poder: 21
newtron Va camino a la fama
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Ahora bien, si lo que quieres es que no salgan repetidos, o algo "especial".
Lo que quiero es que salgan solo los del artículo '001' por ejemplo
__________________
Be water my friend.
Responder Con Cita
  #9  
Antiguo 24-11-2012
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Ahora que veo el ejemplo de newtron (#6)..., me parece que tendríamos que agregar una comprobación a los códigos:
Código SQL [-]
SELECT P.COD_TLTAR, T.COD_TAR, T.NOM_TAR
FROM TL_TARIFAS T, TL_PRECIOS P
WHERE T.COD_TAR = P.COD_TAR
  AND P.COD_TLTAR = :PCOD   /*  esta */
De ese modo y tomando los datos de tu mensaje, pasando como parámetro:
002 nos da:
Código:
COD_TLTAR   COD_TAR  NOM_TAR
002         1        TARIFA 2010  
002         2        TARIFA 2011
y 001
Código:
COD_TLTAR   COD_TAR  NOM_TAR
001         1        TARIFA 2010  
001         2        TARIFA 2011
001         3        TARIFA 2012
Y si no es así, embromate por haberme echo buscar que diablos era "tiquismiquis"...

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
consulta sobre una consulta :D PablorD MySQL 4 02-06-2010 21:59:51
Realizar una consulta sobre los registros que devuelve otra consulta Borjaserrano Firebird e Interbase 12 01-10-2007 23:19:44
Consulta dentro de otra consulta judit25 Conexión con bases de datos 1 25-06-2007 15:52:15
consulta sobre consulta superhopi SQL 2 16-05-2003 19:01:47


La franja horaria es GMT +2. Ahora son las 16:16:54.


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