Codeigniter のアクティブ レコード WHERE 句: 複雑なクエリのグループ化
Codeigniter でアクティブ レコードを使用する場合、必要な状況が発生する可能性があります。複雑なクエリの WHERE 句をグループ化します。これは、入力パラメータに基づいて動的 SQL クエリを生成する場合に特に役立ちます。
Codeigniter バージョン 3 および 4 でこの問題を解決するには、group_start() メソッドと group_end() メソッドを利用できます。
コードイグナイター3
$this->db->select() ->from('users') ->where('name !=', 'Joe') ->group_start() // Open bracket ->where('age <', 69) ->or_where('id <', $id) ->group_end(); // Close bracket
Codeigniter 4
$builder->select('*') ->from('users') ->where('name !=', 'Joe') ->groupStart() ->where('age <', 69) ->orWhere('id <', $id) ->groupEnd();
これらのメソッドを使用すると、WHERE 句を効果的にグループ化し、正しい演算子の優先順位を確保できます。複数の OR 句を使用します。
例として、次のようなシナリオを考えてみましょう。価格範囲に基づいてクエリを動的に生成します:
if ($price_range) { $price_array = explode('.', $price_range); for ($i = 0; $i < count($price_array); $i++) { if ($i == 0) { $this->db->where('places.price_range', $price_array[$i]); } else { $this->db->or_where('places.price_range', $price_array[$i]); } } }
この例では、or_where() の使用に問題があり、演算子の優先順位により予期しない結果が生じる可能性があります。 group_start() と group_end() を使用すると、OR 句をグループ化し、それらが正しく評価されることを確認できます。
以上が複雑なクエリのために CodeIgniter で WHERE 句をグループ化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。