У меня есть некоторые проблемы. Я не могу переопределить переменную правильно, следуя коду.как переопределить переменную типа TStringList
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;
В функции ReturnRightList я заполнить TStringList roleList назначен- prjOne, prjTwo, prjThird. Но после этого я получаю три TStringLists с одним и тем же содержимым. Почему это происходит и как его решить? Спасибо
rolelList должен быть массивом из 3 TStringLists. Измените код для создания roleList [0], roleList [1], roleList [2] и измените код, чтобы обрабатывать соответствующий TStringList каждый раз. – Scooter