AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi TDatabase.DatabaseName und der ganze Rest
Thema durchsuchen
Ansicht
Themen-Optionen

TDatabase.DatabaseName und der ganze Rest

Ein Thema von delphino · begonnen am 9. Jun 2005 · letzter Beitrag vom 10. Jun 2005
Antwort Antwort
delphino

Registriert seit: 4. Mai 2005
11 Beiträge
 
#1

TDatabase.DatabaseName und der ganze Rest

  Alt 9. Jun 2005, 23:55
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.



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
Divide And Conquer !!
  Mit Zitat antworten Zitat
10. Jun 2005, 06:06
Dieses Thema wurde von "Sharky" von "VCL / WinForms / Controls" nach "Datenbanken" verschoben.
Ist glaube ich doch besser in der Datenbanksparte aufgehoben.
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.251 Beiträge
 
Delphi 2006 Professional
 
#3

Re: TDatabase.DatabaseName und der ganze Rest

  Alt 10. Jun 2005, 06:13
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;
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Benutzerbild von eddy
eddy

Registriert seit: 3. Jan 2003
Ort: Sachsen
573 Beiträge
 
Delphi 5 Professional
 
#4

Re: TDatabase.DatabaseName und der ganze Rest

  Alt 10. Jun 2005, 09:37
Hallo delphino,

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

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

mfg
eddy
  Mit Zitat antworten Zitat
delphino

Registriert seit: 4. Mai 2005
11 Beiträge
 
#5

Re: TDatabase.DatabaseName und der ganze Rest

  Alt 10. Jun 2005, 09:47
Nee, iss eine MySQL-Datenbank, die über BDE über MyODBC angesprochen wird.

Gruß delphino
Divide And Conquer !!
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#6

Re: TDatabase.DatabaseName und der ganze Rest

  Alt 10. Jun 2005, 10:22
Hallo Delphino,

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

Grüße vom marabu
  Mit Zitat antworten Zitat
delphino

Registriert seit: 4. Mai 2005
11 Beiträge
 
#7

Re: TDatabase.DatabaseName und der ganze Rest

  Alt 10. Jun 2005, 13:54
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
Divide And Conquer !!
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:40 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