whereメソッドの応用説明

jacklove
リリース: 2023-04-01 08:48:02
オリジナル
2512 人が閲覧しました

where メソッドの使用は、ThinkPHP クエリ言語の本質であり、通常のクエリ、式クエリ、クイック クエリ、間隔クエリ、結合クエリなどのクエリ操作を完了できる、ThinkPHP ORM の重要な部分です。 where メソッドのパラメーターは文字列と配列をサポートしていますが、オブジェクトも使用できますが、お勧めしません。

文字列条件

$User = M("User"); // 实例化User对象$User->where('type=1 AND status=1')->select();
ログイン後にコピー

SELECT * FROM think_user WHERE type=1 AND status=1

配列条件

通常のクエリ

$User = M("User"); // 实例化User对象$map['name'] = 'thinkphp';$map['status'] = 1; // 把查询条件传入查询方法$User->where($map)->select();
ログイン後にコピー

SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1

Expression query

$map['字段1']  = array('表达式','查询条件1');$map['字段2']  = array('表达式','查询条件2');$Model->where($map)->select(); // 也支持
ログイン後にコピー
$map['id']  = array('eq',100);
ログイン後にコピー

は、id = 100

$map['id']  = array('neq',100);
ログイン後にコピー

で表されるクエリ条件を表します。 is id <> 100

$map['id']  = array('gt',100);
ログイン後にコピー

はクエリ条件を表します is id > 100

$map['id']  = array('egt',100);
ログイン後にコピー

はクエリ条件を表します is id >= 100

$map['id']  = array('lt',100);
ログイン後にコピー

はクエリを表します条件は id

$map['id']  = array('elt',100);
ログイン後にコピー

で表されるクエリ条件は id

[NOT] LIKE: SQL の LIKE

$map['name'] = array('like','thinkphp%');
ログイン後にコピー
## と同じです#クエリ条件は 'thinkphp%' のような名前になります

$map['a'] =array('like',array('%thinkphp%','%tp'),'OR');$map['b'] =array('notlike',array('%thinkphp%','%tp'),'AND');
ログイン後にコピー
生成されるクエリ条件は次のとおりです: ('%thinkphp%' または '%tp' のようなもの) AND (b '% thinkphp%' のようなものではありません) AND b not like '%tp')

[NOT] BETWEEN: SQL の [not] between と同じで、クエリ条件は文字列または配列をサポートします。例:

$map['id']  = array('between','1,8');
ログイン後にコピー
$map['id']  = array('between',array('1','8'));
ログイン後にコピー

[NOT] IN: 同sql的[not] in ,查询条件支持字符串或者数组,例如:

$map['id']  = array('not in','1,5,8');
ログイン後にコピー
$map['id']  = array('not in',array('1','5','8'));
ログイン後にコピー

EXP:表达式,支持更复杂的查询情况

$map['id']  = array('exp',' IN (1,3,8) ');
ログイン後にコピー

等同于

$map['id']  = array('in','1,3,8');
ログイン後にコピー

组合查询

$User = M("User"); // 实例化User对象$map['id'] = array('neq',1);$map['name'] = 'ok';$map['_string'] = 'status=1 AND score>10';$User->where($map)->select();
ログイン後にコピー

最后得到的查询条件就成了:( `id` != 1 ) AND ( `name` = 'ok' ) AND ( status=1 AND score>10 )

复合查询

$where['name']  = array('like', '%thinkphp%');$where['title']  = array('like','%thinkphp%');$where['_logic'] = 'or';$map['_complex'] = $where;$map['id']  = array('gt',1);
ログイン後にコピー

等同于

$where['id'] = array('gt',1);$where['_string'] = ' (name like "%thinkphp%")  OR ( title like "%thinkphp") ';
ログイン後にコピー

查询条件是 
( id > 1) AND ( ( name like '%thinkphp%') OR ( title like '%thinkphp%') )

本文讲解了where方法的应用更多相关内容请关注php中文网。

相关推荐:

ThinkPHP 双重循环遍历输出 的相关内容

ThinkPHP5快速入门 方法的介绍

介绍ThinkPHP使用步骤

以上がwhereメソッドの応用説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート