text[]
(配列)列が定義されたPostgreSQLデータベーステーブルがあります。これらの列を使用して、データベース内の特定のレコードを次のように検索しています。
select obj from business
where ((('street' = ANY (address_line_1)
and 'a_city' = ANY (city)
and 'a_state' = ANY (state))
or ('street' = ANY (address_line_1)
and '1234' = ANY (zip_code)))
and ('a_business_name' = ANY (business_name)
or 'a_website' = ANY (website_url)
or array['123'] && phone_numbers))
私が抱えている問題は、約100万件のレコードがあると、クエリが非常に遅くなることです。私の質問は単純ですが、配列列にはさまざまな種類のインデックスがありますか?この場合に作成するのに最適なインデックスのタイプを知っている人はいますか?(さまざまなタイプがあると仮定します)。
念のため、これがexplain analyze
応答です。
"Seq Scan on business (cost=0.00..207254.51 rows=1 width=32) (actual time=18850.462..18850.462 rows=0 loops=1)"
" Filter: (('a'::text = ANY (address_line_1)) AND (('a'::text = ANY (business_name)) OR ('a'::text = ANY (website_url)) OR ('{123}'::text[] && phone_numbers)) AND ((('a'::text = ANY (city)) AND ('a'::text = ANY (state))) OR ('1234'::text = ANY (zip_code))))"
" Rows Removed by Filter: 900506"
"Total runtime: 18850.523 ms"
前もって感謝します!