Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi TDatabase.DatabaseName und der ganze Rest (https://www.delphipraxis.net/47358-tdatabase-databasename-und-der-ganze-rest.html)

delphino 9. Jun 2005 23:55


TDatabase.DatabaseName und der ganze Rest
 
Gab ja schon viele Fragen zu Datenbanken. Vllt ist dies hier mal was neues...

Habe mir eine Klasse geschrieben für Datenbankzugriffe, d.h. wenn ein Frame(Form) was aus ner Datenbank braucht, oder inserten möchte, dann instanziiert es einfach eine DBConnection. Nun möchte ich das alles so frei wie möglich halten und somit während der Entwurfszeit keinerlei Angaben darüber machen wie zur Datenbank verbunden werden soll... Hier ein Beispiel wie es gemeint ist. Das ist natürlich nicht die endgültige DB-Zugriffsklasse, aber bringt das Problem auf den Punkt... Hoffe ich zumindest... ;)

Delphi-Quellcode:
unit Unit3;

interface

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

type
  TForm3 = class(TForm)
    Database1: TDatabase;
    Session1: TSession;
    Query1: TQuery;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
    procedure Database1Login(Database: TDatabase; LoginParams: TStrings);
   
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
 Form3: TForm3;

implementation

{$R *.dfm}

{ MyClass }



procedure TForm3.Database1Login(Database: TDatabase; LoginParams: TStrings);
begin
    with Database do
     begin
      LoginParams.Values['USER NAME'] := 'root';
      LoginParams.Values['Password'] := 'root';
     end;
end;

procedure TForm3.Button1Click(Sender: TObject);
begin

  Database1.DatabaseName := 'owv';
  Database1.AliasName := 'myodbc';
  Query1.DatabaseName := Database1.DatabaseName;
  Session1.SessionName := 'S1';
  Query1.SessionName := Session1.SessionName;
  Query1.Open;
end;

end.
Funktioniert nicht !!! Wenn im Entwurfsmodus Databasename und AliasName nicht angegeben werden.

Fehlermeldung ist, dass der Datenbank Alias 'owv' nicht existiert.

:wiejetzt:

Ich versteh einfach nicht wo Delphi den Unterschied macht. Sobald ich zur Entwurfszeit die Angaben DatabaseName und AliasName mache, funktioniert das ganz toll.

Fürs Helfen im Voraus vielen Dank !!

delphino

DP-Maintenance 10. Jun 2005 06:06

DP-Maintenance
 
Dieses Thema wurde von "Sharky" von "VCL / WinForms / Controls" nach "Datenbanken" verschoben.
Ist glaube ich doch besser in der Datenbanksparte aufgehoben.

Sharky 10. Jun 2005 06:13

Re: TDatabase.DatabaseName und der ganze Rest
 
Hai delphino,

kann es sein das zur Entwurszeit irgenwelche Datenbankverbindung aktiv sind?
Um solche "versehen" zu vermeiden schliesse ich grundsätzlich im .OnCreate immer als erstes die Datenbankverbindung:
Delphi-Quellcode:
procedure TForm1.FormCreate(Sender: TObject);
begin
  Database1.Close;
  // Parameter für die Verbidung setzen
  Database1.Open
end;

eddy 10. Jun 2005 09:37

Re: TDatabase.DatabaseName und der ganze Rest
 
Hallo delphino,

Zitat:

Database1.DatabaseName := 'owv';
Hat Deine Datei keine Erweiterung?

owv.DB
owv.ADT
owv.DBF
owv.<Erweiterung>

mfg
eddy

delphino 10. Jun 2005 09:47

Re: TDatabase.DatabaseName und der ganze Rest
 
Nee, iss eine MySQL-Datenbank, die über BDE über MyODBC angesprochen wird.

Gruß delphino

marabu 10. Jun 2005 10:22

Re: TDatabase.DatabaseName und der ganze Rest
 
Hallo Delphino,

wenn du in deiner Query eine eigene Session-Komponente verwendest, dann sollte Query.SessionName gleich Database.SessionName sein.

Grüße vom marabu

delphino 10. Jun 2005 13:54

Re: TDatabase.DatabaseName und der ganze Rest
 
Hallo !

marabu, das war der entscheidenede Tip !! Allerdings muß man noch aufpassen in welcher Reihenfolge man das alles macht. Hum, also eigentlich versteht sich die Reihenfolge von selbst, aber ich habs natürlich erstmal falsch gemacht... o0

Also de facto habe in meinem Beispiel oben vergessen der Database den SessionName mitzuteilen.


Delphi-Quellcode:
  Database1.DatabaseName := 'owv';
  Database1.AliasName := 'myodbc';
  Session1.SessionName := 'S1';
  Database1.SessionName := Session1.SessionName;
  Query1.DatabaseName := Database1.DatabaseName;
  Query1.SessionName := Session1.SessionName;
  Query1.Open;
Thx a lot !!

Viele Grüße

delphino


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:24 Uhr.

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