* * * *

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.
Maggio 15, 2024, 10:05:48 pm

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

608 Visitatori, 0 Utenti

Autore Topic: [Risolto] Errore su OpenDB con Zeos  (Letto 1232 volte)

petrusic

  • Hero Member
  • *****
  • Post: 593
  • Karma: +0/-0
[Risolto] Errore su OpenDB con Zeos
« il: Marzo 09, 2022, 12:04:03 pm »
.Da ieri mattina cerco di risalire ad un errore che si manifesta durante la Open del mio DB. Sembra un errore logico, ma non ho saputo riconoscere alcuna possibile anomalia.

L'errore è segnalato con la finestra allegata.

Riporto pure il passo di programma incriminato.
Codice: [Seleziona]
function FaiGridVoceSotCto(coVoSotCto, nomiVoce: string): String;  
. . .
 coVoCtoPriCas:= LeftStr(coVoSotCtoCassa, 6) + '000';
          sql:= 'SELECT piancont.NomeVoce FROM piancont WHERE piancont.NumVoce = ' +  coVoSotCtoCassa;
          swOpenErro:= OpenDbZQuery1(sql);
          if not swOpenErro then
          begin
            Form6.ZReadOnlyQuery1.First;
            nomiVoceCassa:= Form6.ZReadOnlyQuery1.FieldByName('NomeVoce').AsString;   // Legge il NomeVoce del SottoConto di Cassa
            Form6.ZReadOnlyQuery1.Close;
            sql:= ' SELECT piancont.NomeVoce FROM piancont WHERE piancont.NumVoce= ' + coVoCtoPriCas;
            swOpenErro:= OpenDbZQuery1(sql);
            if not swOpenErro then
            begin
              Form6.ZReadOnlyQuery1.First;
              nomiVoceCassa:= (Form6.ZReadOnlyQuery1.FieldByName('NomeVoce').AsString) + nomiVoceCassa + '.';   // Legge il NomeVoce del Conto Principale di Cassa
              Form6.ZReadOnlyQuery1.Close;
            end;                                                       
//------------------------------------------------------------   FIN QUI funziona benissimo
 sql:= 'SELECT movimgg.DtCoMovgg, movimgg.DescrMovvgg, movimgg.ImpMovvgg, movimgg.MonMovvgg FROM movimgg ';
            sql:= sql + 'WHERE movimgg.DtCoMovgg >= ' +  dataIni  + ' AND movimgg.DtCoMovgg <= ' + dataFin;
            sql:= sql + ' AND movimgg.CoVocMovvgg = coVoSotCtoCassa ORDER BY movimgg.CoVocMovvgg, movimgg.DtSolMovgg, movimgg.OraSolMovgg';
            WriteLn('sql = "' + sql + '"');
            WriteLn('coVoSotCtoCassa = "' + coVoSotCtoCassa + '"');
//----------------------------------------------------------------------- istruzioni in osservazione -----------------------------------------------------------------
Form6.ZConnect.Database := dbCorr;
 Form6.ZReadOnlyQuery1.SQL.Text := sql;
 try
   Form6.ZReadOnlyQuery1.Open;      // <----------------------- questa Open NON FUNZIONA
   except
   on E: Exception do
   begin
       WriteLn('ERRORE nella OPEN del ContabFamdb (sql: "' + sql + '" ' + IntToStr(E.HelpContext) + ': ' + E.Message);
       swOpenErro:= True;
   end;
 end;
          end;
 if not swOpenErro then
 begin
   nuRec:= Form6.ZReadOnlyQuery1.RecordCount;
 end;
 Form6.ZReadOnlyQuery1.Close;     
. . .             

Non cerco la soluzione al problema. Vorrei capire cosa andare a guardare a cui non ho pensato:
1) ho verificato la stringa sql eseguendo la query con DBBROWSER for SQLite. --> Legge correttamente 64 record
2) ho guardato tutto il percorso eseguito dal programma, verificando che tutte le Open fossero seguite dalle rispettive Close, e ci sono tutte.
ho verificato il nome del DB fornito a ZConnect (dbCorr = '/media/dirdati/dativari/contabfam/ContabFamdb_prove') --> Corretto

 :'(
« Ultima modifica: Marzo 11, 2022, 09:26:18 am da petrusic »
ciao ciao

DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1272
  • Karma: +43/-0
  • Prima ascoltare, poi decidere
Re:Errore su OpenDB con Zeos
« Risposta #1 il: Marzo 09, 2022, 12:44:37 pm »
Non riesco a vedere il dettaglio in questo momento, ma il problema segnalato è che il dataset non è attivo (quindi è in stato ACTIVE = FALSE, oppure è stato fatto una "CLOSE").

La query viene eseguita al momento della messa in stato di TRUE della proprietà ACTIVE, e non deve essere messa in FALSE per tutta la durata delle operazioni (a meno che tu non abbia finito le operazioni e non intenda eseguire un'altra query).

Se esegui un passo passo tramite il debugger con dei breakpoint "mirati" non dovresti avere difficolta a trovare il problema (prova a mettere in WATCH la proprietà ACTIVE della query).
Ciao.
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

 

Recenti

How To

Utenti
Stats
  • Post in totale: 18818
  • Topic in totale: 2241
  • Online Today: 623
  • Online Ever: 900
  • (Gennaio 21, 2020, 08:17:49 pm)
Utenti Online
Users: 0
Guests: 608
Total: 608

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.