Ahoi!
Ich habe hier folgende Struktur (eine Objekt-Relationale Abbildung zu einer
DB, Delphi 2010):
Delphi-Quellcode:
TDB =
class
private
type
TDBUser =
class
private
class var FID: Integer;
class function GetName:
string;
static;
class procedure SetName(
const Value:
string);
static;
// für jedes DB feld eben...
public
class property ID: Integer
read FID;
class property Name:
string read GetName
write SetName;
end;
class var FQuery: TUniQuery;
class var FUser: TDBUser;
class function GetDBUserByLogin(aLogin:
string): TDBUser;
static;
public
class property UsersByLogin[aLogin:
string]: TDBUser
read GetDBUserByLogin;
end;
implementation
class function TDB.GetDBUserByLogin(aLogin:
string): TDBUser;
begin
Query.SQL.Text := '
SELECT id FROM users WHERE login=:lg';
Query.ParamByName('
lg').AsString := aLogin;
Query.Open;
if Query.RecordCount=0
then
begin
Query.Close;
raise EUserDoesNotExistException.Create();
end;
FUser.FID :=
Query.FieldByName('
id').AsInteger;
result := FUser;
Query.Close;
end;
Um die ID eines Users anhand seines Logins zu erhalten, tue ich in einer anderen
Unit dies:
Delphi-Quellcode:
constructor TUser.Create(aLogin, aPassword:
string);
var
id: Integer;
begin
if FInstanceCounter > 0
then
raise Exception.Create('
Es ist bereits ein User angemeldet. Melden Sie diesen ab, bevor Sie sich einloggen.');
try
id := TDB.UsersByLogin[aLogin].ID;
// !!! Hier wichtig !!! :)
except
raise Exception.Create('
Benutzer ''
'+aLogin+'
''
existiert nicht.');
end;
if TDB.Users[id].Password <> aPassword
then
raise Exception.Create('
Ungültiges Passwort für Benutzer ''
'+aLogin+'
''
.');
FId := id;
FLogin := aLogin;
FName := TDB.Users[id].
Name;
FSurname := TDB.Users[id].Surname;
FRights := TDB.Users[id].Rights;
inc(FInstanceCounter);
end;
An der markierten Stelle passiert es dann: NICHTS!
Es wird niemals die Methode GetDBUserByLogin() durchlaufen, und "id" hat nachher immer den Wert "0" (diese ID gibt es nicht in der
DB). Ich erhalte keine Hinweise/Warnungen vom Compiler, kann einen Haltepunkt auf die oben markierte Zeile setzen, ein solcher wird in der Methode GetDBUserByLogin() jedoch deaktiviert. (Das ist die einzige Überladung davon.)
Löschen der DCUs hat leider nichts gebracht, sowie auch das testweise entfernen des try-Blocks. Auch die Optimierung abzuschalten hat an diesem Verhalten nichts geändert.
Bin es nun ich, der einen Denkfehler hat und ihn nicht findet, oder wäre das es wert dem Support vorzutragen?
Besten Dank schon mal!
Medium
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)