Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   error en asignacion de campos en un dbgrid con seleccion multiple (https://www.clubdelphi.com/foros/showthread.php?t=6379)

ElSanto24 05-01-2004 11:27:56

error en asignacion de campos en un dbgrid con seleccion multiple
 
Hola amigos, antes de nada, feliz año nuevo:



Tengo una pequeña duda y me gustaría saber si pueden ayudarme…les cuento:



Tengo que pasar líneas de pedido a producción, para esto, uso un dbgrid donde están las líneas de pedido, y otro donde estarán las líneas que desee pasar a producción, el criterio para pasar a producción no es importante (pertenecerá al usuario de la aplicación), pero debo ofrecer la posibilidad de que elija múltiples líneas del dbgrid y que automáticamente se pasen al dbgrid de producción. Para esto, lo que hago es tener en una línea de pedido, campos booleanos que indican en qué fase está esa línea, por ejemplo, cuando la línea se crea, el campo “pendiente” se pone a verdadero y el resto de campos (esto es…producción, distribución, terminado y pagado) las pongo a falso. Cuando el usuario elige distintas líneas para pasarlas a producción, lo único que debo hacer es poner el flag de producción a verdadero y el de pendiente a falso. Esto es lo que debo obtener, ahora les escribo el siguiente fragmento de código que intenta representar lo que se realizará cuando después de elegir múltiples líneas en el dbgrid se pulse sobre el botón



Button.onclick(Sender:TObject)

var

i:Integer;

begin

if DBGrid1.SelectedRows.Count>0 then

with DBGrid1.DataSource.DataSet do

begin

for i:=0 to DBGrid1.SelectedRows.Count-1 do

begin

GotoBookmark(pointer(DBGrid1.SelectedRows.Items[i]));

FieldValues['pendiente']:=false;

FieldValues['produccion']:=true;

end;

dsflistadoart.Post;

dsflistadoart.Close;

dsflistadoart.Open;

dsflistadoproduccion.close;

dsflistadoproduccion.Open;

end;

end;



En mi humilde opinión creo que el código es correcto (parte de él lo saqué de la ayuda de delphi), sin embargo me muestra un error tal como

“Not in edit Mode”….entiendo el mensaje, pero no entiendo sobre qué he de hacer edit pues tampoco lo indica, si fuera en el dataset mostraría mensaje tal como DataSet not in Edit or Insert Mode que en otras ocasiones me ha aparecido, ademas…está descartado pues he añadido un dbgrid1.datasource.dataset.edit tras la condicion de si su estado no estaba en inserción, pero sigue mostrando el mensaje….a la hora de asignar, he probado con fieldbynames(campo), fields[indice].value, y nada de nada…



Estoy un poco despistado pues no se a que se refiere tal error…



Me podrian ayudar?

Acepto criticas sobre el método que utilizo y sugerencias sobre cómo podría realizarlo

Interbase 7 y delphi 7

Desde ya gracias por vuestra ayuda

:confused:

marcoszorrilla 05-01-2004 17:12:27

Button.onclick(Sender:TObject)

var

i:Integer;

begin

if DBGrid1.SelectedRows.Count>0 then

with DBGrid1.DataSource.DataSet do

begin

for i:=0 to DBGrid1.SelectedRows.Count-1 do

begin

GotoBookmark(pointer(DBGrid1.SelectedRows.Items[i]));
MiTabla.Edit;
FieldValues['pendiente']:=false;

FieldValues['produccion']:=true;

end;

dsflistadoart.Post;

dsflistadoart.Close;

dsflistadoart.Open;

dsflistadoproduccion.close;

dsflistadoproduccion.Open;

end;

end;

Un Saludo.


La franja horaria es GMT +2. Ahora son las 23:48:31.

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