Ich habe ein Problem. Ich kann Variable nicht korrekt neu definieren, indem ich Code folge.Wie definiert man eine TStringList-Typ-Variable
UnitObj.prjOne:=ReturnRightList(0);
for j:=0 to UnitObj.prjOne.Count-1 do
str:=UnitObj.prjOne.ValueFromIndex[j];//here i get for example '32'
UnitObj.prjTwo:=ReturnRightList(1);
for j:=0 to UnitObj.prjTwo.Count-1 do
str1:=UnitObj.prjTwo.ValueFromIndex[j];//here i get for example '40'
for j:=0 to UnitObj.prjOne.Count-1 do
str4:=UnitObj.prjOne.ValueFromIndex[j]; // WHY HERE I GET '42' instead of '32'
UnitObj.prjThird:=ReturnRightList(2);
for j:=0 to UnitObj.prjThird.Count-1 do
str2:=UnitObj.prjThird.ValueFromIndex[j];//here i get for example '42'
procedure TfrmLogin.FormCreate(Sender: TObject);
begin
roleList:=TStringList.Create;
end;
function TfrmLogin.ReturnRightList(bPos:integer):TStringList;
var sqlString:string;
begin
roleList.Clear();
case bPos of
0:sqlString0;//some sql queries
1:sqlString1;
2:sqlString2;
end;
SQLQueryPrjRight.Close;
SQLQueryPrjRight.SQL.Strings[5]:=sqlString;
SQLQueryPrjRight.ParamByName('ID').Value:=uInfo.ID;
SQLQueryPrjRight.Open;
while not SQLQueryPrjRight.EOF do
begin
roleList.Add(IntToStr(SQLQueryPrjRight.FieldByName('pID').AsInteger));
SQLQueryPrjRight.Next;
end;
Result:=roleList;
end;
In Funktion ReturnRightList füllen i in einem TStringList roleList dass prjOne zugeordnet, prjTwo, prjThird. Aber danach bekomme ich drei TStringLists mit demselben Inhalt. Warum passiert es und wie löst man es? Danke
rolelList sollte ein Array von 3 TStringLists sein. Ändern Sie den Code, um roleList [0], roleList [1], roleList [2] zu erstellen, und ändern Sie den Code, um jedes Mal mit der entsprechenden TStringList zu arbeiten. – Scooter