Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   Consulta SQL (https://www.clubdelphi.com/foros/showthread.php?t=81550)

newtron 23-11-2012 19:42:26

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. :D

Gracias y un saludo

ecfisa 23-11-2012 20:08:09

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. :)

Casimiro Notevi 23-11-2012 20:09:23

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?... :p ;)

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


EDITO: bueno, ya contestó ecfisa :)

ecfisa 23-11-2012 20:30:45

Cita:

Empezado por Casimiro Notevi (Mensaje 450342)
EDITO: bueno, ya contestó ecfisa :)

Si, pero no viene mál que le pongas los puntos al desorejado ese... :D:D:D

Saludos.:)

newtron 24-11-2012 09:08:51

Cita:

Empezado por Casimiro Notevi (Mensaje 450342)
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?... :p ;)

Pandilla de tiquismiquis.... por una puñetera línea.....:p

Gracias, voy a hacer alguna prueba.

newtron 24-11-2012 09:38:51

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? :D

Gracias y un saludo

Casimiro Notevi 24-11-2012 12:40:01

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".

newtron 24-11-2012 13:00:22

Cita:

Empezado por Casimiro Notevi (Mensaje 450404)
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

ecfisa 24-11-2012 13:12:58

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.

newtron 24-11-2012 18:23:18

Estupendo.

He conseguido sacar la dichosa consulta.

Ecfisa, Casimiro/Casimiro, Ecfisa, como siempre gracias por vuestra ayuda. De aquí en adelante no os tendré muy en cuenta que seáis unos tiquismiquis. :p

Saludos

newtron 24-11-2012 18:29:29

Uis.... Ahora me diréis que el tiquismiquis soy yo pero revisando el resultado de la consulta me doy cuenta de que los nombres que se le asignan en el resultado de la consulta a las tarifas no corresponden, saca nombres que no son.

La consulta como se ha quedado es la siguiente:

Código SQL [-]
  AdoQuery3.SQL.Clear;
  AdoQuery3.SQL.add('SELECT P.UNI_PRE,P.COD_DIV,P.COD_UNI_MED,P.FVIG_TAR,T.NOM_TAR,P.CAN_MIN,P.TAS_ART');
  AdoQuery3.SQL.add('FROM PUB.TL_TARIFAS T, PUB.TL_PRECIOS P');
  AdoQuery3.SQL.add('WHERE T.COD_TAR = P.COD_TAR');
  AdoQuery3.SQL.add('AND P.NUM_FAB = 2');
  AdoQuery3.SQL.add('AND P.CODTL_ART = '+QuotedStr('0002024665'));
  AdoQuery3.SQL.add('ORDER BY P.FVIG_TAR DESC');
  AdoQuery3.Open;

¿Veis algo raro?

Casimiro Notevi 24-11-2012 18:48:30

FROM PUB.TL_TARIFAS T, PUB.TL_PRECIOS P


¿Qué es eso PUB. ?

newtron 24-11-2012 18:53:30

Cita:

Empezado por Casimiro Notevi (Mensaje 450428)
FROM PUB.TL_TARIFAS T, PUB.TL_PRECIOS P


¿Qué es eso PUB. ?

Pues no tengo ni idea pero sin eso me da error la consulta al conectarme a la base de datos remota por ODBC.

newtron 24-11-2012 19:02:25

Y por otro lado me estoy dando cuenta de que los registros no son correctos.

A ver si me explico, el enlace a la tabla TL_TARIFAS es únicamente para sacar el nombre de la tarifa y ponerlo en la consulta pero la consulta tiene que ser de los registros de la tabla TL_PRECIOS.

Casimiro Notevi 24-11-2012 19:09:56

A ver, no nos lies :p

Esto trae los campos que quieres de la tabla precios y el nombre/descripción de la tarifa. Del artículo que quieras:
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)
where pre.cod_tltar= :elarticuloquequieras
¿No es eso lo que necesitas?

newtron 24-11-2012 19:12:56

Cita:

Empezado por Casimiro Notevi (Mensaje 450434)
A ver, no nos lies :p

Esto trae los campos que quieres de la tabla precios y el nombre/descripción de la tarifa. Del artículo que quieras:
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) where pre.cod_tltar= :elarticuloquequieras

¿No es eso lo que necesitas?


Esta instrucción no he conseguido hacer que funcione, seguiré intentando y te cuento.

newtron 24-11-2012 19:21:26

Negativo, salen nombres de tarifas a lo loco y más registros de los que están originalmente en la tabla TL_PRECIOS :confused:

Casimiro Notevi 24-11-2012 19:38:41

Hombre, pues así, sin ver... no sé, quizás ese campo al que le das el valor tenga otros artículos con el mismo código y espacios entre medios.
'AND P.CODTL_ART = '+QuotedStr('0002024665'));
Aunque también puede ser que el campo por el que están relacionados no sean los correctos:
inner
join tl_tarifas tar on (tar.cod_tar=pre.cod_tar)
O también puede ser que no tengan relación y tengan "cualquier cosa" mal relacionada o sin relación.
¿Qué te devuelve la consulta?

newtron 25-11-2012 09:11:24

Aquí tienes una pantalla con cada consulta y con lo que devuelve





Si te fijas, en la primera consulta devuelve 61 registros cuando los correctos serían los 6 de la segunda imagen que lo hago con un select simple sin ir a buscar el nombre de la tarifa. Por otro lado, el campo COD_TAR en la primera consulta pone siempre el mismo cuando varia de un registro a otro.

Saludos

Casimiro Notevi 25-11-2012 11:33:10

Yo diría que tienes una base de datos no muy "normalizada", veo cosas raras, para empezar, en la primera imagen, el cod_tar=95 en todos los registros, sin embargo su nom_tar es distinto para cada uno :confused:
Diría que no hay una clave foránea correcta entre esos campos de cada tabla y se han metido datos sin control alguno.


La franja horaria es GMT +2. Ahora son las 11:11:05.

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