Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi MS Access-Verbindung funktioniert nur in der IDE (https://www.delphipraxis.net/212080-ms-access-verbindung-funktioniert-nur-der-ide.html)

OsCor 14. Dez 2022 15:49

Datenbank: MS Access • Version: 2019 • Zugriff über: ADO

MS Access-Verbindung funktioniert nur in der IDE
 
Liebe Helfer,

nachdem ich jetzt den richtigen Treiber für den Access-Zugang installiert habe, gibt es bei einer der Anwendungen ein merkwürdiges Phänomen: Im Entwurfsmodus wird die Datenbankverbindung über ADO korrekt durchgeführt und die verbundenen Tabellen werden im DBGrid angezeigt. Aber sobald ich die Anwendung aber starte, kommt die Meldung „Der Provider kann nicht gefunden werden. Möglicherweise ist er nicht richtig installiert worden." und am Schluss ein weiteres Fenster von wegen geschlossener Datenmenge.

Eine Testanwendung mit den gleichen Tabellen funktioniert tadellos.

Auch hier nochmal die Bitte um einen Hinweis.

Gruß
Oswald

Redeemer 15. Dez 2022 10:22

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Bittigkeit der IDE anders als dein Programm, sodass eine andere ODBCAD32 verwendet werden muss?

OsCor 15. Dez 2022 13:54

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Haha, wollte das gerade posten: Was ich nicht bemerkt hatte, war, dass die Testanwendung 32-bittig ist. Gerade ist mir das aufgefallen und ich habe auf 64 Bit umgestellt ---> Aus die Maus, rien ne va plus. Nach dem Zurückstellen auf 32 Bit läuft es wieder.
Also stellt sich jetzt die Frage, ob es eine Konfiguration gibt, mit der ich die Anwendung dazu bringe, auf eine MS-Access 2019-Datenbank etwa mit ADO-Table und Konsorten zugreifen zu können.

Danke fürs Mitdenken!
Oswald

kompi 15. Dez 2022 15:01

AW: MS Access-Verbindung funktioniert nur in der IDE
 
So wie ich es aus dem anderen Post verstanden habe, hast du Office in der 64 bit Version installiert und nachträglich den 32 bit Datenbanktreiber.

Wichtig bei der Sache ist, dass die Adoconnection nicht schon in der IDE verbunden ist, sondern erst während des Programmlaufs.
Ich löse das immer so, dass ich den Connectionstring in der Adoconnection zunächst während des Programmlaufs setze und anschließend Connection auf true setze.
Damit verbindet sich das Programm mit der Datenbank.
Funktioniert sowohl bei 32 als auch 64 bit.

Gruß Kompi

OsCor 15. Dez 2022 15:51

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Das klappt bei mir noch nicht ganz.
Ich setze beim Start der Anwendung den ConnectionString so wie ich ihn vorher in der IDE gesetzt hatte ('Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\XXXXXXX.accdb;Persist Security Info=False') und anschließend setze ich die Eigenschaft Active der Tabelle auf True. Das klappt aber nur bei der 32-bit Version. Fehlt da noch was?

Gruß
Oswald

kompi 15. Dez 2022 17:01

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Welche Komponenten verwendest du?
Ich verwende in meiner Anwendung eine Tadoconnection und nachgeschaltet eine Tadotable.
Gruß Kompi

kompi 15. Dez 2022 17:27

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Ich habe noch mal ein went das Internet bemüht. Es scheint so zu sein, dass die Office 2019 Installation bei CTR (Click to run) die ACE Databaseengine nicht mit installiert, sondern nur eine abgespeckt Engine. Also auch die 64 Bit Engine installieren.
Gruß Kompi

Delphi.Narium 15. Dez 2022 17:31

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Bau Dir mal in Dein Programm 'ne zusätzliche Funktion ein:
Delphi-Quellcode:
function GetConnectionString(Handle       : THandle;
                             ADOConnection : TADOConnection;
                             sConnection  : String = '') : Boolean;
begin
  ADOConnection.Connected       := False;
  // Hier wird der Dialog zum Aufbau des ConnectionString aufgerufen,
  // analog zu dem Aufbau per ObjektInspektor in der IDE.
  ADOConnection.ConnectionString := PromptDataSource(handle,sConnection);
  ADOConnection.Connected       := True;
  Result                        := ADOConnection.Connected;
end;

// Irgendwo am Anfang, z. B. im FormCreate oder wo auch immer sonst
// die Datenbankverbindung bzw. die Tabellen geöffnet werden sollen:
begin
  if GetConnectionString(handle,ADOConnection1) then begin
    // Hier sollte die Datenbankverbindung bestehen.
    // Den ConnctionString kannst Du Dir, bei Bedarf per STRG+C aus dem Dialog
    // kopieren und dann an sinnvoller Stelle speichern bzw. der ADOConnection zuweisen.
    ShowMessage(ADOConnection1.ConnectionString);
  end else begin
    MessageDLG('Es konnte keine Datenbankverbindung hergestellt werden.',mtError,[mbOk],0);
  end;
end;

OsCor 15. Dez 2022 17:45

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Zitat:

Zitat von kompi (Beitrag 1516250)
Welche Komponenten verwendest du?
Ich verwende in meiner Anwendung eine Tadoconnection und nachgeschaltet eine Tadotable.

Genauso mache ich das auch.

Auch eine abgespeckte Engine müsste doch in der Appliste des Systems auftauchen, oder? Da ist bei mir nichts aufgeführt. Welche Engine verwendest denn du?
Außerdem: Wenn ich den 32-bit Treiber verwende, sehe ich ja, wie beim Aufbau des Connection-Strings innerhalb der IDE dieser String aussehen muss. Da muss ich erst mal sehen, wie der 64-bit String aussehen müsste.

@Delphi.Narium
Vermutlich stehe ich ziemlich auf dem Schlauch. Was verbessert sich für mich durch die zusätzliche Funktion?

Gruß
Oswald

kompi 15. Dez 2022 18:24

AW: MS Access-Verbindung funktioniert nur in der IDE
 
Du hast ja auch den 32 Bit ACE Treiber installiert. Jetzt muss noch der 64 Bit ACE Treiber installiert werden. Der wird nicht mitinstalliert.
Gruß Kompi


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:23 Uhr.
Seite 1 von 3  1 23      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz