Heim > Artikel > Backend-Entwicklung > Anwendungserklärung der Where-Methode
Die Verwendung der Where-Methode ist die Essenz der ThinkPHP-Abfragesprache und ein wichtiger Teil und Höhepunkt von ThinkPHP ORM. Sie kann Abfragevorgänge einschließlich gewöhnlicher Abfragen, Ausdrucksabfragen, schneller Abfragen, Intervallabfragen und kombinierter Abfragen durchführen. Die Parameter der where-Methode unterstützen Zeichenfolgen und Arrays. Obwohl auch Objekte verwendet werden können, wird dies nicht empfohlen.
$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);
stellt die durch id = 100 dargestellte Abfragebedingung dar
$map['id'] = array('neq',100);
Die Abfragebedingung is id <> Die durch 100
$map['id'] = array('gt',100);
dargestellte Abfragebedingung ist id >= 100
$map['id'] = array('egt',100);
Die Die Abfragebedingung ist id < 100
$map['id'] = array('lt',100);
Die dargestellte Abfragebedingung ist id <= 100
[NOT] LIKE: Identisch mit SQL's LIKE$map['id'] = array('elt',100);
Die Abfragebedingung wird zu einem Namen wie „thinkphp%“
$map['name'] = array('like','thinkphp%');
Die generierte Abfragebedingung ist: (ein wie „%thinkphp%“ ODER ein wie „%tp“) UND (b nicht wie „%thinkphp%“ ' AND b not like '%tp')
[NOT] BETWEEN: Wie SQLs [not] between unterstützen Abfragebedingungen Zeichenfolgen oder Arrays, zum Beispiel: [NOT] IN: 同sql的[not] in ,查询条件支持字符串或者数组,例如: EXP:表达式,支持更复杂的查询情况 等同于 等同于 查询条件是 本文讲解了where方法的应用更多相关内容请关注php中文网。 相关推荐: Das obige ist der detaillierte Inhalt vonAnwendungserklärung der Where-Methode. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!$map['id'] = array('between','1,8');
$map['id'] = array('between',array('1','8'));
$map['id'] = array('not in','1,5,8');
$map['id'] = array('not in',array('1','5','8'));
$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>
<p style="margin: 10px auto; padding-top: 0px; padding-bottom: 0px; line-height: 19.5px; font-size: 13px; font-family: Verdana, Arial, Helvetica, sans-serif; background-color: rgb(254, 254, 242); text-align: left;">最后得到的查询条件就成了:( `id` != 1 ) AND ( `name` = 'ok' ) AND ( status=1 AND score>10 )</p>
<p style="margin: 10px auto; padding-top: 0px; padding-bottom: 0px; line-height: 19.5px; font-size: 13px; font-family: Verdana, Arial, Helvetica, sans-serif; background-color: rgb(254, 254, 242); text-align: left;"><span style="margin:0px;padding:0px;">复合查询</span></p>
<pre style="margin-top:0px;margin-bottom:0px;padding:0px;white-space:pre-wrap;font-family:'Courier New' !important;" 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%') )