* * * *

Privacy Policy

Blog italiano

Clicca qui se vuoi andare al blog italiano su Lazarus e il pascal.

Forum ufficiale

Se non siete riusciti a reperire l'informazione che cercavate nei nostri articoli o sul nostro forum vi consiglio di visitare il
Forum ufficiale di Lazarus in lingua inglese.

Lazarus 1.0

Trascinare un file nel programma
DB concetti fondamentali e ZeosLib
Recuperare codice HTML da pagina web
Mandare mail con Lazarus
Stabilire il sistema operativo
Esempio lista in pascal
File INI
Codice di attivazione
Realizzare programmi multilingua
Lavorare con le directory
Utilizzare Unità esterne
TTreeView
TTreeview e Menu
Generare controlli RUN-TIME
LazReport, PDF ed immagini
Intercettare tasti premuti
Ampliare Lazarus
Lazarus e la crittografia
System Tray con Lazarus
UIB: Unified Interbase
Il file: questo sconosciuto
Conferma di chiusura di un applicazione
Liste e puntatori
Overload di funzioni
Funzioni a parametri variabili
Proprietà
Conversione numerica
TImage su Form e Panel
Indy gestiore server FTP lato Client
PopUpMenu sotto Pulsante (TSpeedButton)
Direttiva $macro
Toolbar
Evidenziare voci TreeView
Visualizzare un file Html esterno
StatusBar - aggirare l'errore variabile duplicata
Da DataSource a Excel
Le permutazioni
Brute force
Indy 10 - Invio email con allegati
La gestione degli errori in Lazarus
Pascal Script
Linux + Zeos + Firebird
Dataset virtuale
Overload di operatori
Lavorare con file in formato JSON con Lazarus
Zeos ... dietro le quinte (prima parte)
Disporre le finestre in un blocco unico (come Delphi)
Aspetto retrò (Cmd Line)
Lazarus 1.0
Come interfacciare periferica twain
Ubuntu - aggiornare free pascal e lazarus
fpcup: installazioni parallele di lazarus e fpc
Free Pascal e Lazarus sul Raspberry Pi
Cifratura: breve guida all'uso dell'algoritmo BlowFish con lazarus e free pascal.
Creare un server multithread
guida all'installazione di fpc trunk da subversion in linux gentoo
Indice
DB concetti fondamentali e connessioni standard
Advanced Record Syntax
DB concetti fondamentali e DBGrid
DB concetti fondamentali e TDBEdit, TDBMemo e TDBText
Advanced Record Syntax: un esempio pratico
Superclasse form base per programmi gestionali (e non)
Superclasse form base per programmi gestionali (e non) #2 - log, exception call stack, application toolbox
Superclasse form base per programmi gestionali (e non) #3 - traduzione delle form
Superclasse form base per programmi gestionali (e non) #4 - wait animation
Un dialog per la connessione al database:TfmSimpleDbConnectionDialog
Installare lazarus su mac osx sierra
immagine docker per lavorare con lazarus e free pascal
TDD o Test-Driven Development
Benvenuto! Effettua l'accesso oppure registrati.
Aprile 19, 2024, 12:14:51 am

Inserisci il nome utente, la password e la durata della sessione.

182 Visitatori, 0 Utenti

Autore Topic: Dubbi ZeosTable  (Letto 9980 volte)

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Dubbi ZeosTable
« il: 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

« Ultima modifica: Marzo 02, 2014, 11:40:50 am da Diego1981 »

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2870
  • Karma: +20/-4
Re:Dubbi ZeosTable
« Risposta #1 il: 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.
Imagination is more important than knowledge (A.Einstein)

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Re:Dubbi ZeosTable
« Risposta #2 il: 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
« Ultima modifica: Marzo 02, 2014, 11:44:08 am da Diego1981 »

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Re:Dubbi ZeosTable
« Risposta #3 il: 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
« Ultima modifica: Marzo 02, 2014, 07:11:44 pm da Diego1981 »

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2870
  • Karma: +20/-4
Re:Dubbi ZeosTable
« Risposta #4 il: 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 ;)
Imagination is more important than knowledge (A.Einstein)

Stilgar

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2382
  • Karma: +10/-0
Re:Dubbi ZeosTable
« Risposta #5 il: Marzo 03, 2014, 09:48:17 am »
Prova a vedere se questo articolo può aiutarti

http://www.lazaruspascal.it/index.php?page=111
Al mondo ci sono 10 tipi di persone ... chi capisce il binario e chi no.

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Re:Dubbi ZeosTable
« Risposta #6 il: Marzo 03, 2014, 10:42:52 am »
grazie come sempre a tutti!!
 ;D
ora faccio un po' di prove e mi leggo l'articolo

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Re:Dubbi ZeosTable
« Risposta #7 il: 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
« Ultima modifica: Marzo 03, 2014, 03:55:23 pm da Diego1981 »

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Re:Dubbi ZeosTable
« Risposta #8 il: 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

xinyiman

  • Administrator
  • Hero Member
  • *****
  • Post: 3249
  • Karma: +12/-0
Re:Dubbi ZeosTable
« Risposta #9 il: 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
Ieri è passato, domani è futuro, oggi è un dono...

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2870
  • Karma: +20/-4
Re:Dubbi ZeosTable
« Risposta #10 il: 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à
Imagination is more important than knowledge (A.Einstein)

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Re:Dubbi ZeosTable
« Risposta #11 il: 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

Stilgar

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2382
  • Karma: +10/-0
Re:Dubbi ZeosTable
« Risposta #12 il: Marzo 06, 2014, 09:28:21 am »
Prova a sentire direttamente il team di sviluppo di Zeos.
;)

Stilgar
Al mondo ci sono 10 tipi di persone ... chi capisce il binario e chi no.

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2870
  • Karma: +20/-4
Re:Dubbi ZeosTable
« Risposta #13 il: Marzo 06, 2014, 10:18:19 am »
ma in zeos non ci sono le proprietà Filtered e Filter?  :o
Imagination is more important than knowledge (A.Einstein)

Diego1981

  • Full Member
  • ***
  • Post: 180
  • Karma: +0/-0
Re:Dubbi ZeosTable
« Risposta #14 il: 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


 

Recenti

How To

Utenti
  • Utenti in totale: 785
  • Latest: gmax
Stats
  • Post in totale: 18771
  • Topic in totale: 2233
  • Online Today: 167
  • Online Ever: 900
  • (Gennaio 21, 2020, 08:17:49 pm)
Utenti Online
Users: 0
Guests: 182
Total: 182

Disclaimer:

Questo blog non rappresenta una testata giornalistica poiché viene aggiornato senza alcuna periodicità. Non può pertanto considerarsi un prodotto editoriale ai sensi della legge n. 62/2001.