ホームページ >PHPフレームワーク >ThinkPHP >thinkphp の主要なメソッド where() メソッドの詳細な説明

thinkphp の主要なメソッド where() メソッドの詳細な説明

藏色散人
藏色散人転載
2021-12-09 16:43:013804ブラウズ

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

式クエリ

クエリ
$map['字段1']  = array('表达式','查询条件1');
$map['字段2']  = array('表达式','查询条件2');
$Model->where($map)->select(); 
// 也支持
$map['id']  = array('eq',100);

で表される条件は id = 100

$map['id']  = array('neq',100);

id <> 100

# で表されるクエリ条件##
$map[&#39;id&#39;]  = array(&#39;gt&#39;,100);
で表されるクエリ条件は id > 100

$map[&#39;id&#39;]  = array(&#39;egt&#39;,100);
で表されます。id >= 100

$map[&#39;id&#39;]  = array(&#39;lt&#39;,100);
# で表されるクエリ条件は
## で表されるクエリ条件は id < 100

$map[&#39;id&#39;]  = array(&#39;elt&#39;,100);

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

[NOT] LIKE

: LIKE with sql

$map[&#39;name&#39;] = array(&#39;like&#39;,&#39;thinkphp%&#39;);

クエリ条件は 'thinkphp%' のような名前になります

$map[&#39;a&#39;] =array(&#39;like&#39;,array(&#39;%thinkphp%&#39;,&#39;%tp&#39;),&#39;OR&#39;);
$map[&#39;b&#39;] =array(&#39;notlike&#39;,array(&#39;%thinkphp%&#39;,&#39;%tp&#39;),&#39;AND&#39;);

生成されるクエリ条件は次のとおりです。 ('%thinkphp%' のようなもの、または '%tp' のようなもの) AND (b '%thinkphp%' のようなものではない、かつ b '%tp' のようなものではない)

[NOT] BETWEEN

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

$map[&#39;id&#39;]  = array(&#39;between&#39;,&#39;1,8&#39;);

$map[&#39;id&#39;]  = array(&#39;between&#39;,array(&#39;1&#39;,&#39;8&#39;));

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

$map[&#39;id&#39;]  = array(&#39;not in&#39;,&#39;1,5,8&#39;);
$map[&#39;id&#39;]  = array(&#39;not in&#39;,array(&#39;1&#39;,&#39;5&#39;,&#39;8&#39;));

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

$map[&#39;id&#39;]  = array(&#39;exp&#39;,&#39; IN (1,3,8) &#39;);

等同于

$map[&#39;id&#39;]  = array(&#39;in&#39;,&#39;1,3,8&#39;);

组合查询

$User = M("User"); // 实例化User对象
$map[&#39;id&#39;] = array(&#39;neq&#39;,1);$map[&#39;name&#39;] = &#39;ok&#39;;
$map[&#39;_string&#39;] = &#39;status=1 AND score>10';
$User->where($map)->select();</p>
</div>
<p>最后得到的查询条件就成了:( `id` != 1 ) AND ( `name` = 'ok' ) AND ( status=1 AND score>10 ) </p>
<p><strong style="margin:0px;padding:0px;">复合查询</strong></p>
<div class="cnblogs_code" style="margin:5px 0px;padding:5px;background-color:rgb(245,245,245);border:1px solid rgb(204,204,204);overflow:auto;font-size:13px;font-family:'Courier New';"><pre class="brush:php;toolbar:false">$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查询方法。

本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/4994302.html,如需转载请自行联系原作者

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

声明:
この記事はcnblogs.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。