PostgreSQLの配列型JSONでLIKE検索をする
PostgreSQLの配列型のJSONで検索したい人生でしたが無理っぽいということがわかって悲しみにくれています。
たとえばこんな感じのテーブル
|
|
こんな感じのデータに対して like %r% みたいな検索をしたいなと思ったときに無理だなと。
ChatGPT(GPT4)氏によると無理だと言っていた。
配列形式のJSONBに対してLIKE検索を行いたい場合、一般的にはアプリケーション側で配列をループして各要素に対してLIKE検索を行う、または配列の各要素をテキストにキャストしてからLIKE検索を行うなどの方法が考えられます。ただし、これらの方法は効率が良いとは言えませんので、可能であればデータモデルの設計を見直すことをお勧めします。
ちなみにオブジェクト型なら検索出来るらしい
|
|
jsonb_array_elements_textで無理やり検索できる?
stackoverflowのPostgresql: How to perform LIKE query on a json array?の記事を見てたらjsonb_array_elements_textでlike検索できるのでは?という気持ちになってきた。
|
|
こんな感じのクエリで検索できるようになった。
ちなみにJSON型だとキャストが必要なのでこんな感じで書きます。
|
|
最後に
今回は特定の数人が使う管理画面で検索が必要になったので上記のような対応を考えました。
ChatGPTも「可能であればデータモデルの設計を見直すことをお勧めします」といってますし、多くのユーザーが使う場合にはもっと違う方法を考えたほうがいいかと思います。