Italian community of Lazarus and Free Pascal

Programmazione => Databases => Topic aperto da: superc - Dicembre 12, 2022, 11:14:43 am

Titolo: [Risolto] Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 12, 2022, 11:14:43 am
Ciao a tutti,

scusate la domanda, forse un po decontestualizzata, tuttavia oltre ad usare  Lazarus con le Zeos in parecchie mie applicazioni dovrò utilizzarle anche con Delphi che nel mio caso è la versione 11.2; in Lazarus attraverso opm ho installato le Zeos 7.2.14 e funzionano bene sia nella versione a 32bit che a 64 mentre con Delphi sono riuscito a installarle ma funzionano solo nella versione a 32bit mentre se compilo a 64 bit ricevo un errore stranissimo; qualcuno di voi è riuscito per caso a compilarle per delphi 11 e a farle girare su un programma a 64bit?

Grazie anticipatamente.
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: Stilgar - Dicembre 12, 2022, 11:27:46 am
Ciao.
Se l'errore è a runtime, potrebbe essere che non trova le versioni corrette.




Stilgar
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: DragoRosso - Dicembre 12, 2022, 11:32:57 am
Io uso Delphi ma non ho mai installato ZeosLib, in Delphi ci sono le librerie native FireDac e sono identiche funzionalmente a ZeosLib (con un maggiore ausilio visuale nei settaggi di collegamento / opzionali per i database).

Comunque se funzionano a 32 bit dovrebbero funzionare anche a 64 bit.

Che errore viene generato ? A runtime o designtime, in compilazione ?

Ciao
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 12, 2022, 11:51:29 am
Una cosa stranissima: le sto reinstallando e quando ricompilo ZeosDbo.groupproj se lo faccio a 32 bit no problem, se in alto nell'ide di delphi ricompilo a 64 bit, durante la compilazione solo lo zCore280 rimane a 64 bit mentre gli altri vengono automaticamente compilati a 32 bit, come nella foto allegata.
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 12, 2022, 11:54:09 am
Se provo a spostare tipo in Zplain280 il target platform a 64 bit ottengo una serie di errori come nella foto allegata.
L'errore riporta '[dcc64 Fatal Error] ZPlainDriver.pas(58): E2213 Bad packaged unit format: C:\Users\Public\Documents\Embarcadero\Studio\22.0\Dcp\ZCore.dcp.ZClasses - Expected version: 35.0, Windows Unicode(x64) Found version: 35.0, Windows Unicode(x86)';
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 12, 2022, 12:14:51 pm
Le zeos a 32 bit funzionano correttamente, mentre se imposto a 64 bit, collego la dll corretta per il 64bit, setto la property 'Connected' a true ottengo l'errore come in foto.
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: DragoRosso - Dicembre 12, 2022, 03:11:47 pm
Il problema che hai in Delphi è un problema noto legato alla configurazione dei percorsi di libreria nella configurazione di Delphi stesso. Nell'ultima versione "si sono dimenticati" di differenziare il percorso DCP in funzione alla versione 32 / 64....

C'è un patch che risolve questo o si può fare a mano facilmente, io consiglio spassionatamente di farla a mano in quanto la patch "sega" via l'eventuale configurazione personalizzata fatta da voi.

Due minuti e allego le spiegazioni per la risoluzione ......

Riporto dalla patch:

Citazione
Library Path Configuration

The RAD Studio 11.2 installation has an error in the configuration of the library path. Due to this configuration problem, linking with runtime packages fails, as reported in Quality Portal as RSP-39031 (Win64 build with runtime packages can't find Win64 DCP files).
To address the issue you can alternatively:
- Install the .reg file included in the patch download. We recommend you to follow this step only if you have a fresh install with no migrated settings and no third party component installed.

- Use the IDE Tools Options dialog, select Language - Delphi - Library page and there the Windows 64-bit platform. Replace $(BDSCOMMONDIR)\Dcp with  $(BDSCOMMONDIR)\Dcp\$(Platform)
- Open the Windows Registry Editor application (regedit), and make the following changes:
   - In the key HKCU\SOFTWARE\Embarcadero\BDS\22.0\Library\Win64 change the "Search Path" value to "$(BDSLIB)\\$(Platform)\\release;$(BDSUSERDIR)\\Imports\\$(Platform);$(BDSUSERDIR)\\Imports\\$(Platform);$(BDS)\\Imports;$(BDSCOMMONDIR)\\Dcp\\$(Platform);$(BDS)\\include"
   - In the key HKLM\SOFTWARE\WOW6432Node\Embarcadero\BDS\22.0\Library\Win64 change the "Search Path" value to "$(BDSLIB)\\$(Platform)\\release;$(BDSUSERDIR)\\Imports\\$(Platform);$(BDSUSERDIR)\\Imports\\$(Platform);$(BDS)\\Imports;$(BDSCOMMONDIR)\\Dcp\\$(Platform);$(BDS)\\include"
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: nomorelogic - Dicembre 12, 2022, 03:14:28 pm
ciao
Non uso Delphi oramai da un bel po', ma l'errore "E2213 Bad packaged unit format" mi fa pensare che qualche .dcu già compilato a 32 bit, non venga ricompilato a 64.
Forse dovresti provare a fare un bel clean, nel senso di cancellare tutti i .dcu e librerie che hanno a che fare con zeos versione 32bit. Dovresti vedere anche se nelle cartelle tipo "AppData" dell'utente ci sia qualche file relativo alla compilazione.
Insomma devi ripulire tutto per costringere il compilatore a ricompilare ogni sorgente di zeoslib.

Solamente dopo prova a ricompilare a 64 bit.

in bocca al lupo :)
nomorelogic
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: DragoRosso - Dicembre 12, 2022, 03:56:12 pm
Le zeos a 32 bit funzionano correttamente, mentre se imposto a 64 bit, collego la dll corretta per il 64bit, setto la property 'Connected' a true ottengo l'errore come in foto.

Non sò se lo stai facendo da Design, ma visto che riporti il log sono convinto di si .... Delphi è un 32 bit a differenza di Lazarus che è una applicazione a 64 bit (in realtà ci sono le versione a 32 e 64 per Lazarus)

Quindi, quando usi le proprietà a design time (come nel caso delle 'anteprime' dei database) fai attenzione che deve essere tutto a 32 bit. E' per questo che viene consigliato di caricare le appropriate DLL nelle directory di sistema (System32 x dll a 64 bit e SysWow64 x dll a 32 bit). In alternativa devono essere a designtime settate le dll a 32 bit ("driver" della connessione) anche se è configurato l'ambiente a 64 bit come eseguibile finale.

A RunTime è necessario poi cambiare il puntamento alle dl corrette, solo se le DLL non sono nella collocate path di sistema.

Il tutto non è complesso, è più difficile a dirsi che a farsi.

PS: Il nuovo ambiente di Delphi ti consente di "costruire" i settaggi a designtime e di "dimenticarli" a runtime, ovviamente poi a runtime dovrai configurarti tutto a codice. Vedi allegato.


Ciao
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 12, 2022, 04:30:10 pm
Le zeos a 32 bit funzionano correttamente, mentre se imposto a 64 bit, collego la dll corretta per il 64bit, setto la property 'Connected' a true ottengo l'errore come in foto.

Non sò se lo stai facendo da Design, ma visto che riporti il log sono convinto di si .... Delphi è un 32 bit a differenza di Lazarus che è una applicazione a 64 bit (in realtà ci sono le versione a 32 e 64 per Lazarus)

Quindi, quando usi le proprietà a design time (come nel caso delle 'anteprime' dei database) fai attenzione che deve essere tutto a 32 bit. E' per questo che viene consigliato di caricare le appropriate DLL nelle directory di sistema (System32 x dll a 64 bit e SysWow64 x dll a 32 bit). In alternativa devono essere a designtime settate le dll a 32 bit ("driver" della connessione) anche se è configurato l'ambiente a 64 bit come eseguibile finale.

A RunTime è necessario poi cambiare il puntamento alle dl corrette, solo se le DLL non sono nella collocate path di sistema.

Il tutto non è complesso, è più difficile a dirsi che a farsi.

Ciao

Non mi ero accorto ma effettivamente l'ide di Delphi è a 32 bit; si stavo connettendomi con la TConnection in design time a 64 bit, comunque sia all'interno della directory del progetto tengo 2 dir distinte una per le dll a 32 e una per quelle a 64 e a seconda dell'eseguibile che compilo setto la LibraryLocation; cioe in Lazarus faccio cosi ma visto che uso le stesse Zeos sarà uguale... Embarcadero permettendo.
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: DragoRosso - Dicembre 12, 2022, 05:19:47 pm
Non mi ero accorto ma effettivamente l'ide di Delphi è a 32 bit; si stavo connettendomi con la TConnection in design time a 64 bit, comunque sia all'interno della directory del progetto tengo 2 dir distinte una per le dll a 32 e una per quelle a 64 e a seconda dell'eseguibile che compilo setto la LibraryLocation; cioe in Lazarus faccio cosi ma visto che uso le stesse Zeos sarà uguale...

Il concetto è identico anche in Delphi. Usando poi i componenti nativi non devi neanche pensarci. Il problema nasce quando si usano componenti che necessitano di supporto esterno, come DLL o altro. In questo caso, e anche Lazarus ha le stesse problematiche, occorre pensare bene come "sistemare le cose".

Poi ognuno si crea il proprio "standard" con le proprie abitudini.

... Embarcadero permettendo.

 ;D ;D ;D
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 13, 2022, 08:34:40 am
Ora proverò a risolvere e poi vi farò sapere, per il momento grazie a tutti per l'aiuto, a presto  :)
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: nomorelogic - Dicembre 14, 2022, 09:46:11 am
ciao superc
quando sviluppo sotto Win, io ho preso l'abitudine di includere le DLL nella cartella del programma
poi specifico nella stringa di connessione la LibLocation
in questo modo so esattamente quale lib uso e non devo preoccuparmi di cosa c'è installato in Win

esempio:
Codice: [Seleziona]
postgresql://127.0.0.1:5432/mio_database?username=postgres;password=segreto;LibLocation=C:\MioProgramma\Lib\postgres\x64\libpq.dll


Per quanto riguarda lo sviluppo 32/64 bit, con Lazarus - visto che c'è la possibilità - ti consiglio di installare 2 Lazarus diversi: uno a 32bit e l'altro a 64.
So che c'è il cross compiler ma in questo modo puoi lavorare a design-time e fare debug in run-time in modo veloce e certo con i giusti bit.

Ciao
nomorelogic
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 14, 2022, 11:05:10 am
ciao superc
quando sviluppo sotto Win, io ho preso l'abitudine di includere le DLL nella cartella del programma
poi specifico nella stringa di connessione la LibLocation
in questo modo so esattamente quale lib uso e non devo preoccuparmi di cosa c'è installato in Win

esempio:
Codice: [Seleziona]
postgresql://127.0.0.1:5432/mio_database?username=postgres;password=segreto;LibLocation=C:\MioProgramma\Lib\postgres\x64\libpq.dll


Per quanto riguarda lo sviluppo 32/64 bit, con Lazarus - visto che c'è la possibilità - ti consiglio di installare 2 Lazarus diversi: uno a 32bit e l'altro a 64.
So che c'è il cross compiler ma in questo modo puoi lavorare a design-time e fare debug in run-time in modo veloce e certo con i giusti bit.

Ciao
nomorelogic

Ciao nomorelogic,

si concordo con te, la cosa migliore creare all'interno del progetto le 2 dir per le dll; al momento per quando riguarda l'ide uso solo quello a 32 bit perche sto sviluppando un'applicativo a 32 bit. In passato era sviluppato in CodeTyphon ma l'ho convertito tutto per lazarus e non me ne sono pentito per niente, utilizzando l'ottimo fpcupdeluxe.
Per quanto riguarda l'errore originale, in Delphi seguendo le indicazioni di DragoRosso, sono riuscito a installarle e compilarle a 64 bit tuttavia ricevo un altro errore, come se non fossero corrette le dll a 64 bit collegandomi a Postgres, ma questo lo escludo:
ho fatto una controprova, scaricando dal sito di sqlite le dll precompilate a 32bit e a 64 bit, mi sono collegato conm il db prima con la dll a 32 bit e tutto è andato bene mentre a 64 bit ottengo lo stesso errore della foto allegata; se tanto mi da tanto ho sbagliato qualcosa nell'installazione a 64 bit.

Comunque il link che parla di questo problema è
https://blogs.embarcadero.com/rad-studio-11-2-alexandria-patch-1-available/ (https://blogs.embarcadero.com/rad-studio-11-2-alexandria-patch-1-available/)
magari può servire a qualcuno.




Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: nomorelogic - Dicembre 14, 2022, 11:47:07 am
purtroppo con Delphi non ti so essere molto utile in quanto non lo uso oramai da tempo

comunque sia, se l'errore è a runtime, hai provato a specificare LibLocation nella stringa di connessione?
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: DragoRosso - Dicembre 14, 2022, 10:28:38 pm
ho fatto una controprova, scaricando dal sito di sqlite le dll precompilate a 32bit e a 64 bit, mi sono collegato conm il db prima con la dll a 32 bit e tutto è andato bene mentre a 64 bit ottengo lo stesso errore della foto allegata; se tanto mi da tanto ho sbagliato qualcosa nell'installazione a 64 bit.

Comunque il link che parla di questo problema è
https://blogs.embarcadero.com/rad-studio-11-2-alexandria-patch-1-available/ (https://blogs.embarcadero.com/rad-studio-11-2-alexandria-patch-1-available/)
magari può servire a qualcuno.

Ciao, mi scuso per non aver linkato io per primo il riferimento alla patch visto che ne avevo accennato.

Comunque, da quello che vedo stai ancora usando l'IDE a design time ?
Per la connessione a designtime l'IDE fà uso di risorse a 32 bit, indifferentemente dal fatto che il progetto sia a 32 o 64 bit.

L'unica prova che puoi fare a 64 bit è compilare il progetto e "lanciarlo" (anche debugandolo eventualemente).

Le dll che consentono all'IDE l'accesso al database devono essere disponibili all'IDE stesso (quindi o nella cartella BIN dell'IDE o nelle PATH di sistema) e devono essere a 32 bit.

Non ho presente se l'IDE può fare accesso alle DLL presenti nelle cartelle del progetto aperto (ma non penso).

Se nel componente di connessione (ZConnection ad esempio) si può specificare una DLL per quel tipo di DB, allora a designtime deve essere indicato una DLL a 32 bit (se si vuole aprire nell'IDE il DB). Poi a runtime andrai a cambiare il puntamento alla DLL.

Se non sbaglio, prova a cercare PostgreSQL nel forum, c'è stata poco tempo fà una discussione sulla connessione.

Ciao
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 15, 2022, 09:43:56 am
Ciao DragoRosso,

ho installato la patch, ho correttamente settato le path per l'ambiente a 64 bit, ho compilato sia a 32 che a 64bit le zeos (7.2.14) infatti nella directory Dcp di embarcadero crea i file dcp a 64 bit... L'ide a 32 bit funziona correttamente ora e quello che mi dici te torna perche se setto l'eseguibile a 64 bit, e lascio in LibraryLocation la path delle librerie a 32bit mi apre le query, tuttavia se lo lancio mi da errore perche vuole le lib a 64,  giustamente; se setto l'ambiente a 64 bit e metto le library a 64 bit mi rida lo stesso errore 'Check compile-target and library compatibility' ..... A questo punto saranno le dll a 64 bit che non vanno bene oppure magari qualcuna di queste vuole una dipendenza, tipo un'altra dll, che non trova... Sta diventando una questione di principio
Titolo: Re:Zeos lib su lazarus/delphi
Inserito da: superc - Dicembre 15, 2022, 10:22:27 am
Ciao a tutti,

ho risolto, ora funziona tutto: ho inserito le dll a 32 bit nella directory dell'eseguibile generato a 32 bit e lo stesso per quello a 64 bit senza settare la libraryLocation e ora funziona;

ringrazio tutti nuovamente.