Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   locate condicional (https://www.clubdelphi.com/foros/showthread.php?t=21001)

gatsoft2 03-05-2005 18:02:20

locate condicional
 
Queridos amigos.

como siempre recurro a vuestra buena voluntad cuando no soy capaz de resolver algo.

el caso es el siguiente:

trabajo con :

1.- Delphi 6

2.- Mysql

3.- Componentes Zeos

Quiero ubicar el primer registro que cumpla una condicion dentro de una query

Ejemplo :
(Ubicar el primer registro con saldo mayor a cero, de todos los reg de la zona 789 generados con la query)

para lo cual creo una query que me entrega 6 registros como resultado .

la idea es ubicar el primero de esos que cumpla una condicion.

por ejemplo que su saldo sea > 0

Resultado de la Query

Reg.... ID_zona.. Saldo
1 ........789......... 0
2 ........789......... 0
3 ........789......... 0
4 ........789......... 1 -> Ubicar este, pues su Saldo es mayor a cero
5 ........789......... 2
6 ........789........ 44

ósea necesito un locate condicional para hacer la búsqueda sobre la qry

algo así como saldo>0

Nota :
QRY.Locate('Saldo',1,[loCaseInsensitive,loPartialKey]');

que seria ubicar saldo=1

No me sirve pues yo no se cual es el valor que resultara como saldo primero.
Solo se que sera mayor que cero.

de antemano Muchas Gracias


....................

droguerman 03-05-2005 20:59:39

no uso componentes zeos pero prueba esto antes de usar el locate
filter := 'Saldo>0';
filtered := true;

gatsoft2 04-05-2005 00:54:16

Gracias amigo mío por tu respuesta



pero al hacer el filter me mostrara solo los que cumplen esa condición

y lo malo es que el resultado total de la query se debe mostrar en una

grilla. ósea también se deben mostrar los con saldo cero.


Lepe 04-05-2005 10:48:25

Otra solución es usar ORDER BY saldo desc, para obtener primero los que son mayor que cero.

Como ultimo recurso, si necesitas el resultado exactamente así, es recorrer todo el dataset con un bucle.

Un saludo

hermes_32 04-05-2005 15:39:08

Buenas gatsoft2.

En mysql puedes hacer una sentencia para que recupere el primer registro de un grupo que cumple una condicion. Uy qué lio!! Vamos que puedes hacer:

SELECT * FROM Tabla
WHERE Saldo > 0
ORDER BY Reg
LIMIT 1

Esto te recupera el primer valor que te interesa.

Creo haber entendido eso, ¿no?

gatsoft2 04-05-2005 16:38:33

Cita:

Empezado por Lepe
Otra solución es usar ORDER BY saldo desc, para obtener primero los que son mayor que cero.

Como ultimo recurso, si necesitas el resultado exactamente así, es recorrer todo el dataset con un bucle.

Un saludo

gracias por tu cooperación , pero al hacer el orden by la vista de la grilla

también se vera afectada, por lo tanto no me serviría.

ahora parece ser que recorrer como dices tu, con un while la query es la solución mas inmediata pero no la que trataba de encontrar (en ultima instancia tendré que hacer esto).

muchas gracias.

gatsoft2 04-05-2005 16:44:38

Cita:

Empezado por hermes_32
Buenas gatsoft2.

En mysql puedes hacer una sentencia para que recupere el primer registro de un grupo que cumple una condicion. Uy qué lio!! Vamos que puedes hacer:

SELECT * FROM Tabla
WHERE Saldo > 0
ORDER BY Reg
LIMIT 1

Esto te recupera el primer valor que te interesa.

Creo haber entendido eso, ¿no?

Gracias colega por su respuesta.

pero el problema con esta solución es que solo se verán los registros

con saldo mayor a cero y el caso es que deben verse todos.

y ademas ubicar el primero con saldo mayor a cero sin desordenar la vista (query).


gracias por tu ayuda.

hermes_32 04-05-2005 16:49:56

Me parece bien gatsoft2. Pero puedes usar lo que te dije para poder saber el ID en el que te tienes que posicionar.

Una vez que lo sabes puedes hacer:

Código Delphi [-]
  tabla.locate('ID', TuID, []);

Así tienes todos los registros en pantalla y posicionado donde querías.

Un saludo.

gatsoft2 04-05-2005 20:10:29

Cita:

Empezado por hermes_32
Me parece bien gatsoft2. Pero puedes usar lo que te dije para poder saber el ID en el que te tienes que posicionar.

Una vez que lo sabes puedes hacer:

Código Delphi [-]
tabla.locate('ID', TuID, []);

Así tienes todos los registros en pantalla y posicionado donde querías.

Un saludo.

Amigo HERMES_32, tu me dices en el fondo que lo haga de 3 pasos.
1.- ubicar el primer registro con saldo mayor a 0 con una query
2.- rehacer la query, pero mostrando todo
3.- luego usando el resultado del paso 1 hacer el locate.

No esta mal......., muchas gracias por tu tiempo , lo tendre presente.

droguerman 05-05-2005 16:19:29

Intenta Esto
 
ya lo probé debería funcionar con tu problema:

Código:

  var
    marca : string;
    begin
          with miDataset do
          begin
            filter := 'Saldo>0';
            filtered := true;
            first;
            marca := bookmark;
            filtered := false;
            bookmark := marca;
    end;
    end;


gatsoft2 06-05-2005 16:57:37

gracias amigo DROGUERMAN,
Muy Inteligente tu solucion.

Estoy muy agradecido por tu ayuda y la de nuestros otros colegitas.


La franja horaria es GMT +2. Ahora son las 09:45:18.

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