Italian community of Lazarus and Free Pascal
Programmazione => Databases => Topic aperto 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
-
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.
-
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
-
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
-
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 ;)
-
Prova a vedere se questo articolo può aiutarti
http://www.lazaruspascal.it/index.php?page=111
-
grazie come sempre a tutti!!
;D
ora faccio un po' di prove e mi leggo l'articolo
-
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
-
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
-
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
-
non so se è una anomalia, certo è che non è un comportamento comune
mi domando se c'è la possibilità di disabilitare la funzionalità
-
comunque c'è qualcosa che continua a non tornarmi... mi chiedevo .... c'è la possibilità di filtrare i record che vengono modificati nella table?
grazie
diego
-
Prova a sentire direttamente il team di sviluppo di Zeos.
;)
Stilgar
-
ma in zeos non ci sono le proprietà Filtered e Filter? :o
-
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
-
Non preoccuparti diego, sbagliando si impara. Però se hai la caghetta questa sera magari è colpa di qualcuno del forum. ;)
-
Non preoccuparti diego, sbagliando si impara. Però se hai la caghetta questa sera magari è colpa di qualcuno del forum. ;)
:D