Chcete-li předat sadu hodnot, musíte použít typy tabulek nebo polí Oracle.
Nejprve vytvoříte typ tabulky (např. pro NUMBER):
CREATE TYPE number_table AS TABLE OF NUMBER;
Když vytvoříte parametr pro dotaz, deklarujte jej jako asociativní pole PL/SQL:
OracleParameter param1 = new OracleParameter();
param1.OracleDbType = OracleDbType.Int32;
param1.CollectionType = OracleCollectionType.PLSQLAssociativeArray;
Potom přiřaďte nějaké hodnoty:
param1 = new int[] { 3857, 3858, 3863, 3285 };
A váš dotaz vyžaduje obsazení:
SELECT * FROM tablename a
where a.flokkurid in (TABLE(CAST(:manyNumbers AS number_table)))
order by sjodategund, rodun