Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi auf mdb mit OpenDialog zugreifen (https://www.delphipraxis.net/64407-auf-mdb-mit-opendialog-zugreifen.html)

ksh 3. Mär 2006 09:40

Datenbank: Access • Zugriff über: ADO

auf mdb mit OpenDialog zugreifen
 
Morgen!

Greife mit ADO auf meine Access-DB zu und stelle sie in einem DBGrid dar. Das klappt auch.

Möchte jetzt aber eine Laufzeitanbindung mit einer OpenDialog-Komponente zuweisen. Leider scheitert das an meinen fehlenden Delphi-Kenntnissen! Ich hoffe ihr könnt mir da weiterhelfen.

bisher sieht das so aus:

Code:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, Grids, DBGrids, DB, ADODB, StdCtrls;

type
  TForm1 = class(TForm)
    ADOTable1: TADOTable;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form1: TForm1;
  verz: string;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
begin
        close;
end;

end.

mkinzler 3. Mär 2006 09:47

Re: auf mdb mit OpenDialog zugreifen
 
1.) TOpenDialog hinzufügen.
2.)
Delphi-Quellcode:
If OpenDialog.Execute() then
    begin
      //Aktion
    end
    else
     //Es wurde abgebrochem
    begin
    end;
Die ausgewählte Datei(inkl. Pfad) findest du in der Eigenschaft .FileName

In der Hilfe kannst du lesen, wie man die Auswahl auf gewisse Endungen (mdb) beschränkt und wie man einen Pfad voreinstellen kann.

Edit:// end-Tag hinzugefügt

ksh 3. Mär 2006 09:50

Re: auf mdb mit OpenDialog zugreifen
 
In dem tollen Kochbuch steht, dass ich irgendwie noch zur Laufzeit anbinden muss. Stimmt das? und wenn ja - wie mache ich das?

Sidorion 3. Mär 2006 09:52

Re: auf mdb mit OpenDialog zugreifen
 
Über den Open Dialog ermittelst Du nur den Dateinamen deiner Datenbank. Wenn Du den hast, musst Du den Connect-String Deiner DataSource anpassen.
Dazu baust Du Dir am besten erstmal über die IDE einen Connect String zusammen (wie das geht, weisst Du ja).
Diesesn musst Du dann kopieren und als Strin-Konstanten festlegen, und zwar den Teil vor dem Dateinamen und den Teil hinter dem Dateinamen extra.
Wenn jetzt der execute von dienem Open Dialog erfolg hatte, dann nimmst Du diese beiden String-Konstanten, hängst dazwischen den Filenamen aus dem Open-Dialog und vóilà Du hast einen neuen Connect-string für die DataSource.
Diese musst du jetzt deakivieren, den neuen String zuweisen und wieder aktivieren.

mkinzler 3. Mär 2006 09:53

Re: auf mdb mit OpenDialog zugreifen
 
Zitat:

Zitat von ksh
In dem tollen Kochbuch steht, dass ich irgendwie noch zur Laufzeit anbinden muss. Stimmt das? und wenn ja - wie mache ich das?

Für den OpenDialog nicht. Oder meinst du das mit der ADOTable? Der mußt du natürlich die im OpenDialog ausgewählte mdb zuweisen.

Sharky 3. Mär 2006 10:08

Re: auf mdb mit OpenDialog zugreifen
 
Hai ksh,

hier mal ein Beispiel das Dir eventuell helfen wird:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  dbpasswort : string;
  DataBaseFileName : string;
begin
  dbpasswort := ''; // DB Kennwort
  if (OpenDialog1.Execute) then // OpenDialog ausführen
  begin
    DataBaseFileName := OpenDialog1.FileName; // Pfad und Dateiname der DB-Datei
    with ADOConnection1 do
    begin
      Close;
      ConnectionString := Format('Provider=%s; Data Source=%s; ' +
        'Persist Security Info=False; Jet OLEDB:Database PassWord=%s',
        ['Microsoft.Jet.OLEDB.4.0',
        DatabaseFileName,
        dbpasswort]);
      Open;
      GetTableNames(ListBox1.Items); // Alle Tabellen der DB in ListBox anzeigen
    end;
  end;
end;
Wie Du siehst brauchst Du einen Button, eine Listbox, einen OpenDialog und eine ADOConnection auf der Form.

ksh 3. Mär 2006 10:10

Re: auf mdb mit OpenDialog zugreifen
 
Ich glaube so theoretisch ist bei mir jetzt alles klar. Muss jetzt nur noch versuchen, das irgendwie in die Praxis umzusetzen. und das kann dauern :(

Vielen dank! werde mich gleich mal an dem Beispiel versuchen!

ksh 3. Mär 2006 10:21

Re: auf mdb mit OpenDialog zugreifen
 
verzeiht mir die wahrscheinlich saudumme Frage: :gruebel:
wann kann ich eine unit starten und wann nicht? würde gerne das Ding jetzt ausprobieren - aber ich kann es nicht starten.

Klaus01 3. Mär 2006 10:27

Re: auf mdb mit OpenDialog zugreifen
 
normalerweise mit F9

wenn das nicht geht, was sagt/zeigt denn der Compiler
(in dem Abschnitt unter dem Editor) warum es
nicht geht wenn Du Ctrl+F9 drückst?

Grüße
Klaus

Luckie 3. Mär 2006 10:28

Re: auf mdb mit OpenDialog zugreifen
 
Für eine neue Frage, erstell bitte einen neuen Thread. Danke.


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:32 Uhr.
Seite 1 von 2  1 2      

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