Как кто-то более опытный с Oracle DB, я тоже был обеспокоен этим ограничением. Я провел тест производительности для запроса с ~ 10'000 параметров в IN
-списке, выбирая простые числа до 100'000 из таблицы с первыми 100'000 целыми числами , фактически перечисляя все простые числа числа в качестве параметров запроса .
Мои результаты показывают, что вам не нужно беспокоиться о перегрузке оптимизатора плана запросов или получении планов без использования индекса , поскольку он преобразует запрос в = ANY({...}::integer[])
, где он может использовать индексы, как и ожидалось:
-- prepare statement, runs instantaneous:
PREPARE hugeplan (integer, integer, integer, ...) AS
SELECT *
FROM primes
WHERE n IN ($1, $2, $3, ..., $9592);
-- fetch the prime numbers:
EXECUTE hugeplan(2, 3, 5, ..., 99991);
-- EXPLAIN ANALYZE output for the EXECUTE:
"Index Scan using n_idx on primes (cost=0.42..9750.77 rows=9592 width=5) (actual time=0.024..15.268 rows=9592 loops=1)"
" Index Cond: (n = ANY ('{2,3,5,7, (...)"
"Execution time: 16.063 ms"
-- setup, should you care:
CREATE TABLE public.primes
(
n integer NOT NULL,
prime boolean,
CONSTRAINT n_idx PRIMARY KEY (n)
)
WITH (
OIDS=FALSE
);
ALTER TABLE public.primes
OWNER TO postgres;
INSERT INTO public.primes
SELECT generate_series(1,100000);