>PHP 프레임워크 >ThinkPHP >thinkphp 주요 메소드 where() 메소드에 대한 자세한 설명

thinkphp 주요 메소드 where() 메소드에 대한 자세한 설명

藏色散人
藏色散人앞으로
2021-12-09 16:43:013775검색

where 메소드의 사용법은 ThinkPHP쿼리 언어의 핵심이자 ThinkPHP ORM의 중요한 부분이자 하이라이트입니다. 일반 쿼리, 표현식 쿼리, 빠른 쿼리, 간격 쿼리 및 결합 쿼리를 포함한 쿼리 작업을 완료할 수 있습니다. where 메소드의 매개변수는 문자열과 배열을 지원하지만 객체를 사용할 수도 있지만 권장되지 않습니다.

문자열 조건

$User = M("User"); // 实例化User对象$User->where('type=1 AND status=1')->select();

SELECT * FROM think_user WHERE 유형=1 AND 상태=1

배열 조건

일반 쿼리

$User = M("User"); 
// 实例化User对象
$map['name'] = 'thinkphp';
$map['status'] = 1; 
// 把查询条件传入查询方法
$User->where($map)->select();

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

로 표현되는 쿼리 조건은 id = 100

$map['字段1']  = array('表达式','查询条件1');
$map['字段2']  = array('表达式','查询条件2');
$Model->where($map)->select(); 
// 也支持
입니다. 쿼리 조건은 id <> 100

$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입니다.

[NOT] LIKE
: SQL LIKE

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

와 동일 쿼리 조건은 'thinkphp%'와 같은 이름이 됩니다.

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

생성된 쿼리 조건은 다음과 같습니다. (a like '%thinkphp%' OR a like ' %tp') AND (b not like '%thinkphp%' AND b not like '%tp')

[NOT] BETWEEN
: SQL의 [not] between과 동일, 쿼리 조건은 문자열 또는 배열을 지원합니다. 예를 들어 :

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

$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;);

[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();</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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제