* * * *

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 29, 2024, 08:07:33 pm

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

464 Visitatori, 1 Utente
 

Autore Topic: path del database  (Letto 7755 volte)

tiberi72

  • Full Member
  • ***
  • Post: 101
  • Karma: +0/-0
    • Pagina Personale
path del database
« il: Ottobre 03, 2012, 09:45:41 am »
Ciao,
so che in questi giorni vi sto martellando, ma ho incontrato dei problemi che all'inizio neanche mi sognavo.
Ho sviluppato (come avrete ben capito) un programmino in lazarus e vorrei spostarlo su un altro pc.
Fino ad ora la path del database, impostata su un oggetto TIBConnection, era assoluta e puntava alla cartella dove sono memorizzati tutti i miei sorgenti.
Ora dovrei spostarla.
Ho provato ad utilizzare sul codice application.location, ma il programma segnala comunque errore perche' il percorso assoluto che utilizzo nel sorgente e' utilizzato anche nel file .lfm.
Come posso fare per inserire un percorso relativo direttamente nell'oggetto TIBConnection?

Voi di solito come avete risolto il problema?

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2870
  • Karma: +20/-4
Re:path del database
« Risposta #1 il: Ottobre 03, 2012, 02:40:05 pm »
Con un file .ini
Imagination is more important than knowledge (A.Einstein)

tiberi72

  • Full Member
  • ***
  • Post: 101
  • Karma: +0/-0
    • Pagina Personale
Re:path del database
« Risposta #2 il: Ottobre 04, 2012, 09:52:27 am »
Con un file .ini
Penso di non essermi spiegato troppo bene: io ho i miei sorgenti (incluso il relativo db) in C:\Documents and Settings\Utente\Documenti\sorgenti\prova
Nel computer dove dovro' istallare il programma il db (che e' sempre nella stessa cartella dell'eseguibile) sara' nella cartella c:\prg\ .
il problema e' che quando vado sul computer definitivo il programma mi da errore per il database sul percorso C:\Documents and Settings\Utente\Documenti\sorgenti\prova\ (che ovviamente non esiste), anche se imposto il nome del database da sorgente con application.location + 'dati.fdb'
« Ultima modifica: Ottobre 04, 2012, 10:33:30 am da tiberi72 »

El Salvador

  • Visitatore
Re:path del database
« Risposta #3 il: Ottobre 04, 2012, 02:29:01 pm »
Citazione
Ho provato ad utilizzare sul codice application.location, ma il programma segnala comunque errore perche' il percorso assoluto che utilizzo nel sorgente e' utilizzato anche nel file .lfm.
Ma non riesci ad utilizzare i percorsi relativi e quindi modificare la proprietà del percorso in runtime, prima di usare il componente?

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2870
  • Karma: +20/-4
Re:path del database
« Risposta #4 il: Ottobre 04, 2012, 04:20:56 pm »
se usi un TIBConnection vuol dire che usi Firebird
imposta un alias in aliases.conf

semplicemente con una riga
MYDB = c:\prg\database.fdb

nel componente, a design time, ci metti MYDB come percorso (oppure 127.0.0.1:MYDB) e dovrebbe funzionare

Certo è che a runtime qualcosa nella riassegnazione della path del DB non funziona :)
Imagination is more important than knowledge (A.Einstein)

xinyiman

  • Administrator
  • Hero Member
  • *****
  • Post: 3249
  • Karma: +12/-0
Re:path del database
« Risposta #5 il: Ottobre 04, 2012, 04:49:36 pm »
Mi sembra strano. A me ha sempre funzionato il metodo Application.Location


Prova a usare i file ini così dovresti risolvere il problema, spulcia gli how to. E' un argomento già trattato :)
Ieri è passato, domani è futuro, oggi è un dono...

Stilgar

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2382
  • Karma: +10/-0
Re:path del database
« Risposta #6 il: Ottobre 04, 2012, 08:45:53 pm »
Ciao,
 io uso un trucco molto semplice.
Siccome la connessione punta con l'ide al DB, ma poi voglio avere il controllo su quello che fa l'applicazione a runtime, uso 2 configurazioni.
Una a Design e una a Runtime.
La cosa importante è che la connessione all'avvio dell'applicazione sia off.
Altrimenti all'avvio prova a connettersi e va tutto a scatafascio.
Quindi imposto a runtime il mio bel path e attivo la connessione al DB.
Insomma, metà della roba che con l'ide posso fare la disabilito e connetto tutto a manina ;)
Database, DataSource.
Alla fine è un loop banalissimo. Sia in creazione che in distruzione dei componenti.
Altra cosa che faccio è spostare tutta la parte "backend" in di un DataModule.
Sovrascrivo il costruttore e il distruttore, in modo che connettano e sconnettano tutto.
Questo perchè non voglio incasinare altre parti dell'applicazione. D'altra parte è uno dei principi dell'incapsulamento della OOP :D
EDIT:
Altro vantaggio.
Se esplode qualche cosa in connessione è dentro il loop e non dentro i meccanismi sui quali non ho controllo ;)
Al mondo ci sono 10 tipi di persone ... chi capisce il binario e chi no.

tiberi72

  • Full Member
  • ***
  • Post: 101
  • Karma: +0/-0
    • Pagina Personale
Re:path del database
« Risposta #7 il: Ottobre 09, 2012, 10:39:58 am »
Mi sembra strano. A me ha sempre funzionato il metodo Application.Location


Prova a usare i file ini così dovresti risolvere il problema, spulcia gli how to. E' un argomento già trattato :)
In effetti e' strano, perche' in alcuni casi, nonostante io imposti a false tutti i connected, mi da errore e non riesco a modificare il databasename perche' mi dice che e' gia' connesso.
In un programma di questi quando rivado in lazarus addirittura vedo nella tibconnection connected=true, mentre se apro con notepad il file .lfm vedo connected = false

 

Recenti

How To

Utenti
Stats
  • Post in totale: 18781
  • Topic in totale: 2235
  • Online Today: 414
  • Online Ever: 900
  • (Gennaio 21, 2020, 08:17:49 pm)
Utenti Online
Users: 1
Guests: 464
Total: 465

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.