Italian community of Lazarus and Free Pascal

Programmazione => Databases => Topic aperto da: Diego1981 - Marzo 02, 2014, 08:03:11 am

Titolo: Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 02, 2014, 08:03:11 am
Ciao Ragazzi
come va?
volevo sottopovi una curiosità che mi sta capitando usando le ztable.
Ho due tabelle Mysql: la prima chiamata prenotazioni e la seconda ospiti.
La tabella ospiti ha, tra le varie colonne, una colonna che è la chiave esterna della tabella prenotazioni.
Quando salvo i dati sul db con il compando ApplyUpudates faccio si che le chiavi esterne della tabella ospiti vengano aggiornate (la procedura è la seguente)

ZT_Ospiti.First;
  while not ZT_Ospiti.EOF do
       begin
         ZT_Ospiti.Edit;
         ZT_Ospiti.FieldByName('idPrenotazione').AsInteger:= IdPrenotazione;
         ZT_Ospiti.Post;
         ZT_Ospiti.Next;
      end;

il dubbio è il seguente:

il comando NEXT deve o non deve essere inserito, perchè ho altre tabelle nel db con il medesimo concetto e mentre con le altre tabelle il NEXT mi crea problemi (e non lo metto) con questa tabella invece devo per forza metterlo altrimenti il ciclo continua a ripetersi.....No capisco il perchè.
grazie a tutti come sempre
Diego

Titolo: Re:Dubbi ZeosTable
Inserito da: nomorelogic - Marzo 02, 2014, 11:09:46 am
il codice riportato qua sotto è corretto

Noto solo che sulla riga del .Next hai usato anche il riferimento al datamodule mentre prima no. Ma questo non è un problema quì (a patto che tu abbia 1 solo datamodule istanziato in memoria).

Dovresti quindi indagare sugli altri casi in cui il .Next ti da problemi e non lo metti. A me risulta che non vada messo esclusivamente dopo un .Delete in quanto, cancellando una riga, lo spostamento al record successivo è automatico.
Titolo: Re:Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 02, 2014, 11:38:48 am
Ciao Nomore
il riferimento al datamodule era un'errore di copiatura scusa, di fatto la procedura è nel datamodule all'evento  BeforeApplyUpdates.


ZT_DatiPrenotazioni.First;
  while not ZT_DatiPrenotazioni.EOF do
        begin
          ZT_DatiPrenotazioni.Edit;        ZT_DatiPrenotazioni.FieldByName('idPrenotazione').AsInteger:=IdPrenotazione;
          ZT_DatiPrenotazioni.Post;
          //ZT_DatiPrenotazioni.Next;
        end;

il codice che ti ho appena riportato è sempre inserito nello stesso DataModule e all'evento BeforeApplyUpdates di un'altra table ma come vedi ho "disattivato" il next perchè altrimenti non scorreva tutti i record mentre cosi li scorre senza problemi fino alla fine.
Non riesco a capire
Titolo: Re:Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 02, 2014, 07:03:45 pm
Rieccomi Sempre più confuso

qui c'è qualcosa che non funziona
ogni volta che avvio il programma la questione cambia....una volta ho bisogno del next mentre l'altra non c'è più bisogno..azz
sarà mica impazzito lazarus  :'(

ho provato anche a riavviare il sistema ma la cosa è sempre saltuaria e stravagante  ;D (cose non molto utili mentre si fa un programmino eheheh)

Diego
Titolo: Re:Dubbi ZeosTable
Inserito da: nomorelogic - Marzo 03, 2014, 09:08:43 am
come già detto, il Next ci vuole e qua non ci piove
quello che mi preoccupa è il fatto che ogni volta che avvii il programma la situazione cambia: questo non ha veramente alcun senso

Partendo però dal presupposto che i fantasmi non esistono (almeno nella programmazione :P), la magagna si potrebbe nascondere nei vari OnBefore e/o OnAfter di Edit, Post. Potrebbe anche essere nell'ondatachange, onstatechange, onrecordchange (forse qualche nome di evento non è quello giusto ma poco importa).

Devi andare di debugger o, se non ci riesci, il consiglio: commenta tutto il codice nei vari eventi (tutti, non dare nulla per scontato) e decommenta il Next che deve funzionare (e sempre allo stesso modo).

Una volta riottenuto il funzionamento corretto (e sempre allo stesso modo), puoi riabilitare un evento alla volta.

buon lavoro ;)
Titolo: Re:Dubbi ZeosTable
Inserito da: Stilgar - Marzo 03, 2014, 09:48:17 am
Prova a vedere se questo articolo può aiutarti

http://www.lazaruspascal.it/index.php?page=111
Titolo: Re:Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 03, 2014, 10:42:52 am
grazie come sempre a tutti!!
 ;D
ora faccio un po' di prove e mi leggo l'articolo
Titolo: Re:Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 03, 2014, 03:04:41 pm
mi è sorto un dubbio sia andando di debugger sia leggendo l'articolo di stilgar
ho notato che scorrendo la table e aggiorndando qualche dato (in questo caso la chiave esterna) il next viene eseguito in automatico mentre scorrendo la table senza che nessun dato venga modificato il next non viene eseguito automaticamente.
quindi se riuscissi a sapere se i dati sono stati modificati o meno avrei risolto il problema.
Ricordo che con ADO si potevano clonare le tabelle e poi aggiornare solamente i record modificati (VADO A RICORDO)
Zeos permette qualcosa del genere che voi sappiate?
grazie
Diego
Titolo: Re:Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 04, 2014, 08:36:26 am
ho fatto diverse prove ed è proprio cosi
se i record vengono modificati il next lo esegue in automatico mentre se non vengono modificati il next non lo esegue in automatico
è un comportamento anomalo che vi risulti?
grazie
diego
Titolo: Re:Dubbi ZeosTable
Inserito da: xinyiman - Marzo 04, 2014, 10:49:21 am
knon penso sia anomalo in quanto anche sulle dbgrid per far si che il post sul record avvenga bisogna cambiare riga. probabilmente loro lo hannno gestito cosi
Titolo: Re:Dubbi ZeosTable
Inserito da: nomorelogic - Marzo 04, 2014, 03:03:19 pm
non so se è una anomalia, certo è che non è un comportamento comune
mi domando se c'è la possibilità di disabilitare la funzionalità
Titolo: Re:Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 05, 2014, 11:55:10 am
comunque c'è qualcosa che continua a non tornarmi... mi chiedevo .... c'è la possibilità di filtrare i record che vengono modificati nella table?
grazie
diego
Titolo: Re:Dubbi ZeosTable
Inserito da: Stilgar - Marzo 06, 2014, 09:28:21 am
Prova a sentire direttamente il team di sviluppo di Zeos.
;)

Stilgar
Titolo: Re:Dubbi ZeosTable
Inserito da: nomorelogic - Marzo 06, 2014, 10:18:19 am
ma in zeos non ci sono le proprietà Filtered e Filter?  :o
Titolo: Re:Dubbi ZeosTable
Inserito da: Diego1981 - Marzo 06, 2014, 06:25:49 pm
ragazzi ho risolto e....sono un'idiota  :-X azz
il fatto che il next avvenisse in modo automatico non era poi cosi automatico, a forza di prova e riprova sono arrivato al dunque, il fatto è che io filtravo la table in base all'id e di conseguenza ogni volta che aggiornazo i record questi sparivano dalla tabella e scalavano, mentre per i record gia aggiornati il next era necessario perchè l'id era assegnato.
spero di essermi spiegato.
di certo ho disturbato tutti per niente
mea culpa  :o
diego

Titolo: Re:Dubbi ZeosTable
Inserito da: xinyiman - Marzo 06, 2014, 06:31:42 pm
Non preoccuparti diego, sbagliando si impara. Però se hai la caghetta questa sera magari è colpa di qualcuno del forum.  ;)
Titolo: Re:Dubbi ZeosTable
Inserito da: nomorelogic - Marzo 06, 2014, 06:39:19 pm
Non preoccuparti diego, sbagliando si impara. Però se hai la caghetta questa sera magari è colpa di qualcuno del forum.  ;)

 :D