ホームページ >PHPフレームワーク >ThinkPHP >thinkphp の主要なメソッド where() メソッドの詳細な説明
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['id'] = array('gt',100);で表されるクエリ条件は id > 100
$map['id'] = array('egt',100);で表されます。id >= 100
$map['id'] = array('lt',100);# で表されるクエリ条件は
$map['id'] = array('elt',100);
: LIKE with sql
$map['name'] = array('like','thinkphp%');
$map['a'] =array('like',array('%thinkphp%','%tp'),'OR'); $map['b'] =array('notlike',array('%thinkphp%','%tp'),'AND');
: 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();</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 サイトの他の関連記事を参照してください。