Если массив содержит последовательные значения, то запрос составляется просто, например:
select * from table1 where id >= 2 and id <= 10
Если массив содержит не регулярную последовательность значений, то без цикла не обойтись, в котором и составляется условие поиска для WHERE. Если, конечно, массив не гигантский.
Код:
function CreateParam(MasId : array of Integer) : string;
var
I : INteger;
begin
Result := '';
if Length(MasId) = 0 then Exit;
Result := ' id IN ('+IntToStr(MasId[0]);
for I := 1 to High(MasId) do
Result := Result + ','+IntToStr(MasId[i]);
Result := Result + ')';
end;
В результате должна получится строка типа: ' id in (1,5,6,4,2)'.
И в первом варианте и во втором параметр должен быть строкового типа.
А запрос должен выглядеть несколько иначе:
select * from table1 where :MasId
Первый вариант:
Код:
if Length(ArrayId) > 0 then
ADODataSet1.Parameters.ParamByName('MasId').Value :=
'id>='+IntToStr(ArrayId[0])+' and id<='+IntToStr(ArrayId[High(ArrayId)]);
Второй:
Код:
S := CreateParam(ArrayId);
if S <> '' then
ADODataSet1.Parameters.ParamByName('MasId').Value := S;
"ArrayId" - массив чисел, в котором уже есть необходимые значения идентификаторов
И в первом случае можно обойтись вторым вариантом. Будет создана строка типа: ' id in (1,2,3,4,5,6)'.