ホームページ  >  記事  >  バックエンド開発  >  複数フィールドのあいまい一致クエリを実装するための thinkPHP メソッド

複数フィールドのあいまい一致クエリを実装するための thinkPHP メソッド

不言
不言オリジナル
2018-05-03 16:10:432472ブラウズ

この記事では主に、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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。