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 25-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Select anidados

Hola a todos

Si tengo una tabla con dos campos: Tiques y Codigos

quiero obtener una consulta que saque Tiques que tengan 3 mismos codigos

Ejemplos Tiques que tengan los 1000,1001,1002
Tiques Codigos
1 1000
1 1001
1 1002
1 1003
2 1000
2 1002
3 1000
3 1001
3 1002

Tendría que darnos
Tiques
1
3

Yo creo que se hace con Select Anidados pero por vueltas que
estoy dando a los anidamientos no lo consigo

A ver si alguien tiene alguna idea y me puede ayudar

Muchas gracias a todos
Responder Con Cita
  #2  
Antiguo 25-11-2009
Avatar de afunez2007
afunez2007 afunez2007 is offline
Miembro
 
Registrado: oct 2007
Ubicación: La Ceiba, Honduras
Posts: 170
Poder: 17
afunez2007 Va por buen camino
Lightbulb

La Solucion es esta:

Código SQL [-]
SELECT     TIQUES, COUNT(TIQUES) AS CUENTA
FROM         Table_1
GROUP BY TIQUES
HAVING      (COUNT(*) > 2)

te dara como resultado
TIQUES CUENTA
1 4
3 3

Saludos
__________________
Si robas, roba un beso, si mientes que sea por amor y si engañas que sea a la muerte!!
Responder Con Cita
  #3  
Antiguo 25-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Muchas gracias por responderme

No me explique del todo bien. Estoy usando Firebird y en la tabla
los tiques no tienen porque ir seguidos pueden ser totalmente diferentes al
igual que los codigos que también pueden ser diferentes no me valdrían los
mayor y menor que
tiene que ser algo genérico

hay que tener en cuenta que la tabla va a tener miles de tiques y de
Codigos
tienen que cumplir la condicion de que haya un tique para estos 3 codigos

Ejemplos Tiques que tengan los 1050,1024,1030
Tiques Codigos
5 1050
5 1024
3 1030
5 1080
6 1050
6 1030
5 1030
3 1050
3 1024
4 1024
4 1050
4 1100
4 1200


daría

Tique
5
3


Muchas gracias
Responder Con Cita
  #4  
Antiguo 25-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Habia pensado en algo parecido a esto

Código SQL [-]

      'Select DISTINCT t1.Tique, t1.Codigo from CODIGOSFIN as t1 ' +
      ' where Codigo = 1050 ' +
                                'AND Exists ' +
     '(Select t1.Tique from CODIGOSFIN where Codigo = 1024) ' +

//                                 'AND Codigo IN ' +
//      '(Select Codigo from CODIGOSFIN where Codigo = 3)) ' +
      'Order By Tique';


Claro que me da mal

Muchas gracias
Responder Con Cita
  #5  
Antiguo 25-11-2009
Avatar de afunez2007
afunez2007 afunez2007 is offline
Miembro
 
Registrado: oct 2007
Ubicación: La Ceiba, Honduras
Posts: 170
Poder: 17
afunez2007 Va por buen camino
Lightbulb

Pues todavia no entiendo bien lo que quieres hacer, se me ocurre esto: Ingrese esa tabla de datos que pusiste y probe el siguiente codigo:

Código SQL [-]
SELECT DISTINCT TIQUE FROMCODIGOSFIN WHERE CODIGO=1050 OR (CODIGO=1024) or (CODIGO=1030)

y me devuelve lo siguiente:
TIQUE
3
4
5
6
__________________
Si robas, roba un beso, si mientes que sea por amor y si engañas que sea a la muerte!!
Responder Con Cita
  #6  
Antiguo 25-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
es que eso no valdría

Tendría que dar
Tique
5
3

el 5 cumple la condicion de que tiene un Codigo 1050 y un Codigo 1030 y
un codigo 1024

y el 3 lo mismo

espero haberme explicado un poco mejor

Saludos
Responder Con Cita
  #7  
Antiguo 25-11-2009
Avatar de afunez2007
afunez2007 afunez2007 is offline
Miembro
 
Registrado: oct 2007
Ubicación: La Ceiba, Honduras
Posts: 170
Poder: 17
afunez2007 Va por buen camino
Lightbulb

Ahora voy entendiendo que es lo que quieres hacer, depues de varias pruebas creo que la solucion seria asi:

Código SQL [-]
SELECT  TIQUE,COUNT(TIQUE) AS CUENTA FROM CODIGOSFIN  WHERE CODIGO=1024 or CODIGO=1030 or CODIGO=1050    GROUP BY TIQUE HAVING COUNT(*)=3

Esto devuelve:
TIQUE CUENTA
--3------3----
--5------3----
__________________
Si robas, roba un beso, si mientes que sea por amor y si engañas que sea a la muerte!!
Responder Con Cita
  #8  
Antiguo 26-11-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Eso es lo mismo que antes

al final lo he hecho con delphi y parece que funciona
algo parecido a esto

Código Delphi [-]

    tblCodigosFin.Open;
    tblCodigosFin.IndexFieldNames := 'TIQUE;CODIGO';

  list := TStringList.Create;
  list.Add('1');
  list.Add('3');
  list.Add('5');

  listSeleccionado := TStringList.Create;

  TiqueAnterior := '';
  tblCodigosFin.First;
  while not tblCodigosFin.Eof do
  begin

    Tique := tblCodigosFin.FieldByName('Tique').AsString;
    Codigo := tblCodigosFin.FieldByName('Codigo').AsInteger;

    if Tique <> TiqueAnterior then
    begin
//       TiqueAnterior := Tique;

       if listSeleccionado.Count =
          list.Count then
       begin

         tblSeleccion.Append;
         tblSeleccion.FieldByName('Tique').AsString := TiqueAnterior;
//       tblSeleccion.FieldByName('Codigo').AsInteger := Codigo;
         tblSeleccion.Post;
       end;

       listSeleccionado.Clear;
       TiqueAnterior := Tique;

    end
    else begin
       if list.IndexOf(IntToStr(Codigo)) >= 0 then
         if listSeleccionado.IndexOf(IntToStr(Codigo)) < 0 then
           listSeleccionado.Add(IntToStr(Codigo));

    end;



    tblCodigosFin.next;
  end;


Gacias a todos y saludos
Responder Con Cita
  #9  
Antiguo 26-11-2009
Avatar de afunez2007
afunez2007 afunez2007 is offline
Miembro
 
Registrado: oct 2007
Ubicación: La Ceiba, Honduras
Posts: 170
Poder: 17
afunez2007 Va por buen camino
Lightbulb

Bien siempre hay distintas formas de hacer, las cosas aunque utilizaste un metodo mas largo, podrias optimizarlo utilizando una query con el codigo que te envie, ya que me parece que seria mas rapido que utilizar un ciclo que recorra la tabla, ya que mencionaste que tenia muchos registros

Saludos
__________________
Si robas, roba un beso, si mientes que sea por amor y si engañas que sea a la muerte!!
Responder Con Cita
  #10  
Antiguo 26-11-2009
Avatar de Axel_Tech
Axel_Tech Axel_Tech is offline
Miembro
 
Registrado: nov 2008
Ubicación: lugar en que está ubicado algo.
Posts: 85
Poder: 16
Axel_Tech Va por buen camino
No la he probado pero creo que la consulta correcta sería algo así:
Código SQL [-]
SELECT DISTINCT TIQUE 
FROM CODIGOSFIN A 
WHERE EXISTS (SELECT TIQUE FROM CODIGOSFIN B WHERE A.TIQUE=B.TIQUE AND CODIGO=1050)
AND EXISTS (SELECT TIQUE FROM CODIGOSFIN B WHERE A.TIQUE=B.TIQUE AND CODIGO=1024)
AND EXISTS (SELECT TIQUE FROM CODIGOSFIN B WHERE A.TIQUE=B.TIQUE AND CODIGO=1030) 
ORDER BY TIQUE
__________________
No hope, no dreams, no love, my only escape is Underground
Responder Con Cita
  #11  
Antiguo 27-11-2009
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

Esta creo que tambien Funciona:
Código SQL [-]
Select distinct Tiques from CodigosFin cf
Where Codigos in(1050,1024,1030)
and (Select count(cf.Tiques)from CodigosFin aux where cf.Tiques=aux.Tiques)>=3;
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
Responder Con Cita
  #12  
Antiguo 04-12-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Muchas gracias a todos por contestarme

Pensaba que ya se había acabado el hilo y por eso no volví a mirarlo.

Lo de Axel si funciona , yo había pensado algo por el estilo pero no sabía como implementarlo. Lo que si, es que es mas lento que haciéndolo sólo
con delphi. He hecho algo como lo siguiente porque
podrían ser para 100 códigos o más


Código Delphi [-]

  list := TStringList.Create;
  list.Add('1');
  list.Add('3');
  list.Add('5');



   qrySeleccion.SQL.Clear;
   qrySeleccion.SQL.Add(
     'SELECT DISTINCT Tique ' +
     'FROM CODIGOSFIN A ' +
     'WHERE EXISTS ' +
       ' (SELECT TIQUE FROM CODIGOSFIN B WHERE A.TIQUE=B.TIQUE ' +
       ' AND CODIGO= ' + list[0] + ' ) ');

   for i := 1 to list.Count -1 do
     qrySeleccion.SQL.Add(
      ' AND EXISTS ' +
        ' (SELECT TIQUE FROM CODIGOSFIN B WHERE A.TIQUE=B.TIQUE ' +
        ' AND CODIGO= ' + list[i] + ' ) ');


     qrySeleccion.SQL.Add('ORDER BY TIQUE, CODIGO');

     qrySeleccion.Open;


Lo de tuAmigo lo he probado aunque no lo entiendo muy bien y para
mas de 100 códigos se podría complicar la cosa.
Código SQL [-]
     'Select distinct Tiques from CodigosFin cf ' +
     ' Where Codigo in(1,3,5) ' +
     ' and (Select count(cf.Tique) from CodigosFin aux ' +
        ' where cf.Tique=aux.Tique)>=3 ';


Me da un error:
Cannot use un aggregate function in a where clause, use habing instead


Y lo que hice yo tiene un pequeño bug que lo he solucionado

Código Delphi [-]
  tblCodigosFin.First;
  while not tblCodigosFin.Eof do
  begin

    Tique := tblCodigosFin.FieldByName('Tique').AsString;
    Codigo := tblCodigosFin.FieldByName('Codigo').AsInteger;

    if Tique <> TiqueAnterior then
    begin
//       TiqueAnterior := Tique;

       if listSeleccionado.Count =
          list.Count then
       begin

         tblSeleccion.Append;
         tblSeleccion.FieldByName('Tique').AsString := TiqueAnterior;
//       tblSeleccion.FieldByName('Codigo').AsInteger := Codigo;
         tblSeleccion.Post;

       end;

       listSeleccionado.Clear;
       TiqueAnterior := Tique;

    end;

       if list.IndexOf(IntToStr(Codigo)) >= 0 then
         if listSeleccionado.IndexOf(IntToStr(Codigo)) < 0 then
           listSeleccionado.Add(IntToStr(Codigo));


    tblCodigosFin.next;
  end;

        if listSeleccionado.Count =
          list.Count then
       begin

         tblSeleccion.Append;
         tblSeleccion.FieldByName('Tique').AsString := TiqueAnterior;
//       tblSeleccion.FieldByName('Codigo').AsInteger := Codigo;
         tblSeleccion.Post;

       end;


ahora si me da bien y es bastante rápido

Muchas gracias a todos y pido disculpas por no haber contestado antes
Responder Con Cita
  #13  
Antiguo 05-12-2009
Avatar de rgstuamigo
rgstuamigo rgstuamigo is offline
Miembro
 
Registrado: jul 2008
Ubicación: Santa Cruz de la Sierra-Bolivia
Posts: 1.646
Poder: 17
rgstuamigo Va por buen camino
Arrow

Cita:
Empezado por jaimeh Ver Mensaje
...
Pensaba que ya se había acabado el hilo y por eso no volví a mirarlo.
...
En realidad un hilo en el Club Delphi nunca termina, siempre hay personas quienes quieren agregar algo.... Y quien mas que tú, para estar pendiente y atento al hilo que iniciaste.

Cita:
Empezado por jaimeh Ver Mensaje
...
Lo de tuAmigo lo he probado aunque no lo entiendo muy bien y para
mas de 100 códigos se podría complicar la cosa.
...
Bueno no acabo de entenderte , primero dices que solo quires buscar para tres específicos códigos(1050,1024,1030), ahora ya dices que van a ser mas de 100 códigos, pues entonces mas bien te convendria sacar todos los Tiques que se repiten 3 o mas veces algo asi:
Código SQL [-]
Select distinct Tiques from CodigosFin cf
where(Select count(cf.Tiques)from CodigosFin aux where cf.Tiques=aux.Tiques)>=3;
Saludos...
__________________
"Pedid, y se os dará; buscad, y hallaréis; llamad, y se os abrirá." Mt.7:7
Responder Con Cita
  #14  
Antiguo 08-12-2009
jaimeh jaimeh is offline
Miembro
 
Registrado: mar 2007
Posts: 68
Poder: 18
jaimeh Va por buen camino
Gracias por respoderme amigo

al principio puse un ejemplo de lo que tenía que dar el select para un caso particular esperando una respuesta de un algoritmo para n códigos, que puede que no me expresara bien del todo. La idea de axel era como yo lo pensaba pero no sabía escribirlo.
Al final lo que hice fue modificar lo de axel y funciono, aunque volviera hacerlo para tres códigos 1,3,5 (list) en el ejemplo pero ese algoritmo funciona para n códigos, es el algoritmo que puse mas arriba.

En tu algoritmo amigo no pones los codigos que se van a mirar que pueden ser n códigos de números.

De todas formas gracias por dedicarme tiempo amigo

saludos a todos
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
Datasets anidados Gong Conexión con bases de datos 2 20-07-2007 16:05:41
ayuda con dos for anidados Nelly Varios 4 03-06-2006 21:37:22
Clientdatasets anidados con ADO Johnny Q Conexión con bases de datos 4 03-11-2005 02:53:25
Filtros anidados.... Phacko Conexión con bases de datos 2 19-03-2005 19:41:31
Select anidados Ignacio SQL 5 23-02-2004 16:33:30


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


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