この記事では主に、thinkPHP で複数フィールドのあいまい一致クエリを実装する方法を紹介し、あいまい一致クエリの関連モデル操作と thinkPHP の SQL ステートメントを例の形式で分析します。この記事では、thinkPHP での複数フィールドのあいまい一致クエリの実装について説明します。参考のために皆さんと共有してください。詳細は次のとおりです:
はじめに: 場合によっては、クエリは複数のフィールドと一致する必要があります。たとえば、住所をクエリする場合、住所は複数のフィールドで構成されます。詳細な住所だけでなく、州、市、地区などもあります。この時点でクエリを実行するにはどうすればよいですか?
異なるフィールドに同じクエリ条件を実装します
$User = M("User"); // 实例化User对象 $map['name|title'] = 'thinkphp'; // 把查询条件传入查询方法 $User->where($map)->select();
プロジェクトで使用してください
if ($address) { // 地址查询 $where['b.province|b.city|b.area|b.detail'] = array('like', '%'.$address.'%'); $this->assign('address', $address); }
この要件は非常に簡単かつ正確に解決されます。
生成されたSQL文は以下の通りです
SELECT a.*,b.name,b.tel,b.province,b.city,b.area,b.detail,b.zipcode FROM sh_order a LEFT JOIN sh_member_address b on a.member_id = b.member_id and b.selected = 1 WHERE ( `store_id` = '10' ) AND ( a.member_id IN ('7') ) AND ( (b.province LIKE '%宿城区%') OR (b.city LIKE '%宿城区%') OR (b.area LIKE '%宿城区%') OR (b.detail LIKE '%宿城区%') ) ORDER BY addtime desc, sendtime asc, paytime desc LIMIT 0,10
SQL文を見ると、whereの中のかっこ、AND、ORが非常に巧妙に組み合わされていることがわかります。
スクリーンショットは次のとおりです
関連する推奨事項:
フレームワーク Thinkphp5 動作フックの単純な実装 Hook以上が複数フィールドのあいまい一致クエリを実装するための thinkPHP メソッドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。