Maison > développement back-end > tutoriel php > Explication détaillée de la façon d'utiliserwhere() dans ThinkPHP

Explication détaillée de la façon d'utiliserwhere() dans ThinkPHP

不言
Libérer: 2023-03-30 07:56:01
original
2617 Les gens l'ont consulté

Cet article présente principalement l'explication détaillée de l'utilisation de Where() dans ThinkPHP. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer

La méthode Where peut. être utilisé pour base de données Filtrer les résultats de l’opération. C'est-à-dire la clause Where dans l'instruction de requête SQL. Cet article vous présente l'explication détaillée de l'utilisation de la méthode Where() dans ThinkPHP. Les amis intéressés peuvent se référer à

Cet article présente l'utilisation de la méthode Where() dans ThinkPHP. La méthode Where peut être utilisée pour filtrer les résultats des opérations de base de données. C'est-à-dire la clause Where dans l'instruction de requête SQL.

Aujourd'hui, je vais vous parler de la méthode Where, qui est la requête la plus couramment utilisée mais aussi la plus complexe. La méthode Where est également l'une des méthodes de fonctionnement cohérentes de la classe modèle et est principalement utilisée pour les requêtes. et réglage des conditions de fonctionnement.

L'utilisation de la méthode Where est l'essence du langage de requête ThinkPHP et une partie importante et un point fort de l'ORM ThinkPHP. Elle peut compléter des requêtes, notamment des requêtes ordinaires, des requêtes d'expression, des requêtes rapides, des requêtes à intervalles et des requêtes combinées. les requêtes fonctionnent. Les paramètres de la méthode Where prennent en charge les chaînes et les tableaux. Bien que les objets puissent également être utilisés, cela n'est pas recommandé.

Conditions de chaîne

Utilisez des conditions de chaîne pour interroger et opérer directement, par exemple :

$User = M("User"); // 实例化User对象
$User->where('type=1 AND status=1')->select();
Copier après la connexion

L'instruction SQL finale générée est

SELECT * FROM think_user WHERE type=1 AND status=1
Copier après la connexion

Si vous utilisez la version 3.1 ou supérieure, lorsque vous utilisez des conditions de chaîne, elle il est recommandé de coopérer avec le mécanisme de prétraitement pour assurer une plus grande sécurité, comme :

$Model->where("id=%d and username='%s' and
xx='%f'",array($id,$username,$xx))->select();
Copier après la connexion

ou d'utiliser :

$Model->where("id=%d and username='%s' and xx='%f'",$id,$username,$xx)->select();
Copier après la connexion

Si la variable $id provient de la soumission de l'utilisateur ou de l'adresse URL, si l'entrée est de type non numérique, elle sera forcée d'être formatée dans un format numérique avant l'interrogation.
Le type de format de prétraitement de chaîne prend en charge la spécification de nombres, de chaînes, etc. Pour plus de détails, veuillez vous référer à la description des paramètres de la méthode vsprintf.

Condition du tableau

L'utilisation de la condition du tableau est celle recommandée par ThinkPHP.

Requête normale

La méthode de requête de tableau la plus simple est la suivante :

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

L'instruction SQL finale générée est

SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1
Copier après la connexion

Requête d'expression

La condition de requête ci-dessus n'est qu'un simple jugement d'égalité. Vous pouvez utiliser des expressions de requête pour prendre en charge davantage de syntaxe de requête SQL :

$map['字段1'] = array('表达式','查询条件1');
$map['字段2'] = array('表达式','查询条件2');
$Model->where($map)->select(); // 也支持
Copier après la connexion

<🎜. >

Les expressions ne sont pas sensibles à la casse. Les expressions de requête suivantes sont prises en charge et leurs significations respectives sont :

Signification de l'expression

EQ est égal à (=)

NEQ n'est pas égal à (<>)
GT est supérieur à (>)
EGT est supérieur ou égal à (>=)
LT est inférieur à (< ;)
ELT inférieur ou égal à (<=)
LIKE requête floue
[NOT] ENTRE (pas dans) requête d'intervalle
[NOT] IN (pas in) Requête IN
Requête d'expression EXP, prend en charge la syntaxe SQL

Les exemples sont les suivants :

EQ : égal à (=)

Par exemple :

$map[&#39;id&#39;] = array(&#39;eq&#39;,100);
Copier après la connexion

est équivalent à la requête suivante

$map[&#39;id&#39;] = 100;
Copier après la connexion

La condition de requête représentée par.

est id = 100

NEQ : Différent de ( <>)

Par exemple :

$map[&#39;id&#39;] = array(&#39;neq&#39;,100);
Copier après la connexion

représente l'identifiant de la condition de requête <> 100

GT : supérieur à (>)

Par exemple :

$map[&#39;id&#39;] = array(&#39;gt&#39;,100);
Copier après la connexion

représente l'identifiant de la condition de requête > 100

EGT : Supérieur ou égal à (>=)

Par exemple :

$map[&#39;id&#39;] = array(&#39;egt&#39;,100);
Copier après la connexion

représente l'identifiant de la condition de requête >= 100

LT : inférieur à (<)

Par exemple :

$map[&#39;id&#39;] = array(&#39;lt&#39;,100);
Copier après la connexion

représente l'identifiant de la condition de requête < 100

ELT : inférieur ou égal à (<=)

Pour exemple :

$map[&#39;id&#39;] = array(&#39;elt&#39;,100);
Copier après la connexion

représente l'identifiant de la condition de requête <= 100

[NOT] LIKE : identique à SQL LIKE

Par exemple :

$map[&#39;name&#39;] = array(&#39;like&#39;,&#39;thinkphp%&#39;);
Copier après la connexion

requête La condition devient un nom comme 'thinkphp%'

Si le paramètre DB_LIKE_FIELDS est configuré, certains champs effectueront automatiquement des requêtes floues. Par exemple, si vous définissez :

&#39;DB_LIKE_FIELDS&#39;=>&#39;title|content&#39;
Copier après la connexion

, utilisez

$map[&#39;title&#39;] = &#39;thinkphp&#39;;
Copier après la connexion

pour interroger La condition deviendra un nom comme '%thinkphp%'
prend en charge le mode tableau, par exemple,

$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;);
Copier après la connexion

La condition de requête générée est :

(a like &#39;%thinkphp%&#39; OR a like &#39;%tp&#39;) AND (b not like &#39;%thinkphp%&#39; AND b not like &#39;%tp&#39;)
Copier après la connexion

[NOT] BETWEEN : comme pour [not] between de SQL, les conditions de requête prennent en charge les chaînes ou les tableaux, par exemple :

$map[&#39;id&#39;] = array(&#39;between&#39;,&#39;1,8&#39;);
Copier après la connexion

est équivalent à ce qui suit :

$map[&#39;id&#39;] = array(&#39;between&#39;,array(&#39;1&#39;,&#39;8&#39;));
Copier après la connexion

La condition de requête devient id BETWEEN 1 AND 8

[NOT] IN : Identique à [not] in de SQL, les conditions de requête prennent en charge les chaînes ou les tableaux, par exemple :

$map[&#39;id&#39;] = array(&#39;not in&#39;,&#39;1,5,8&#39;);
Copier après la connexion

et Ce qui suit est équivalent :

$map[&#39;id&#39;] = array(&#39;not in&#39;,array(&#39;1&#39;,&#39;5&#39;,&#39;8&#39;));
Copier après la connexion

La condition de requête devient id NOT IN (1,5, 8)

EXP : Formule d'expression pour prendre en charge des situations de requêtes plus complexes

Par exemple :

$map[&#39;id&#39;] = array(&#39;in&#39;,&#39;1,3,8&#39;);
Copier après la connexion

可以改成:

$map[&#39;id&#39;] = array(&#39;exp&#39;,&#39; IN (1,3,8) &#39;);
Copier après la connexion

exp查询的条件不会被当成字符串,所以后面的查询条件可以使用任何SQL支持的语法,包括使用函数和字段名称。

查询表达式不仅可用于查询条件,也可以用于数据更新,例如:

$User = M("User"); // 实例化User对象
// 要修改的数据对象属性赋值
$data[&#39;name&#39;] = &#39;ThinkPHP&#39;;
$data[&#39;score&#39;] = array(&#39;exp&#39;,&#39;score+1&#39;);// 用户的积分加1
$User->where(&#39;id=5&#39;)->save($data); // 根据条件保存修改的数据
Copier après la connexion

快捷查询

where方法支持快捷查询方式,可以进一步简化查询条件的写法,例如:

一、实现不同字段相同的查询条件

$User = M("User"); // 实例化User对象
$map[&#39;name|title&#39;] = &#39;thinkphp&#39;;
// 把查询条件传入查询方法
$User->where($map)->select();
Copier après la connexion

查询条件就变成 name= 'thinkphp' OR title = 'thinkphp'

二、实现不同字段不同的查询条件

$User = M("User"); // 实例化User对象
$map[&#39;status&title&#39;] =array(&#39;1&#39;,&#39;thinkphp&#39;,&#39;_multi&#39;=>true);
// 把查询条件传入查询方法
$User->where($map)->select();
Copier après la connexion

'_multi'=>true必须加在数组的最后,表示当前是多条件匹配,这样查询条件就变成 status= 1 AND title = 'thinkphp' ,查询字段支持更多的,例如:

$map[&#39;status&score&title&#39;] =array(&#39;1&#39;,array(&#39;gt&#39;,&#39;0&#39;),&#39;thinkphp&#39;,&#39;_multi&#39;=>true);
Copier après la connexion

查询条件就变成 status= 1 AND score >0 AND title = 'thinkphp'

注意:快捷查询方式中“|”和“&”不能同时使用。

区间查询

where方法支持对某个字段的区间查询,例如:

$map['id'] = array(array('gt',1),array('lt',10)) ;

得到的查询条件是: (`id` > 1) AND (`id` < 10)

$map['id'] = array(array('gt',3),array('lt',10), 'or') ;

得到的查询条件是: (`id` > 3) OR (`id` < 10)

$map['id'] = array(array('neq',6),array('gt',3),'and');

得到的查询条件是:(`id` != 6) AND (`id` > 3)
最后一个可以是AND、 OR或者 XOR运算符,如果不写,默认是AND运算。

区间查询的条件可以支持普通查询的所有表达式,也就是说类似LIKE、GT和EXP这样的表达式都可以支持。另外区间查询还可以支持更多的条件,只要是针对一个字段的条件都可以写到一起,例如:

$map[&#39;name&#39;] = array(array(&#39;like&#39;,&#39;%a%&#39;), array(&#39;like&#39;,&#39;%b%&#39;), array(&#39;like&#39;,&#39;%c%&#39;), &#39;ThinkPHP&#39;,&#39;or&#39;);
Copier après la connexion

最后的查询条件是:

(`name` LIKE &#39;%a%&#39;) OR (`name` LIKE &#39;%b%&#39;) OR (`name` LIKE &#39;%c%&#39;) OR (`name` = &#39;ThinkPHP&#39;)
Copier après la connexion

组合查询

组合查询用于复杂的查询条件,如果你需要在查询的时候同时偶尔使用字符串却又不希望丢失数组方式的灵活的话,可以考虑使用组合查询。

组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string)、复合查询(_complex)、请求字符串查询(_query),混合查询中的特殊查询每次查询只能定义一个,由于采用数组的索引方式,索引相同的特殊查询会被覆盖。

一、字符串模式查询(采用_string 作为查询条件)

数组条件还可以和字符串条件混合使用,例如:

$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&#39;;
$User->where($map)->select();
Copier après la connexion

最后得到的查询条件就成了:

( `id` != 1 ) AND ( `name` = &#39;ok&#39; ) AND ( status=1 AND score>10 )
Copier après la connexion

二、请求字符串查询方式

请求字符串查询是一种类似于URL传参的方式,可以支持简单的条件相等判断。

$map[&#39;id&#39;] = array(&#39;gt&#39;,&#39;100&#39;);
$map[&#39;_query&#39;] = &#39;status=1&score=100&_logic=or&#39;;
Copier après la connexion

得到的查询条件是:`id`>100 AND (`status` = '1' OR `score` = '100')

三、复合查询

复合查询相当于封装了一个新的查询条件,然后并入原来的查询条件之中,所以可以完成比较复杂的查询条件组装。
例如:

$where[&#39;name&#39;] = array(&#39;like&#39;, &#39;%thinkphp%&#39;);
$where[&#39;title&#39;] = array(&#39;like&#39;,&#39;%thinkphp%&#39;);
$where[&#39;_logic&#39;] = &#39;or&#39;;
$map[&#39;_complex&#39;] = $where;
$map[&#39;id&#39;] = array(&#39;gt&#39;,1);
Copier après la connexion

查询条件是

( id > 1) AND ( ( name like &#39;%thinkphp%&#39;) OR ( title like &#39;%thinkphp%&#39;) )
Copier après la connexion

复合查询使用了_complex作为子查询条件来定义,配合之前的查询方式,可以非常灵活的制定更加复杂的查询条件。

很多查询方式可以相互转换,例如上面的查询条件可以改成:

$where[&#39;id&#39;] = array(&#39;gt&#39;,1);
$where[&#39;_string&#39;] = &#39; (name like "%thinkphp%") OR ( title like "%thinkphp") &#39;;
Copier après la connexion

最后生成的SQL语句是一致的。

多次调用

3.1.3版本开始,where方法支持多次调用,但字符串条件只能出现一次,例如:

$map[&#39;a&#39;] = array(&#39;gt&#39;,1);
$where[&#39;b&#39;] = 1;
$Model->where($map)->where($where)->where(&#39;status=1&#39;)->select();
Copier après la connexion

多次的数组条件表达式会最终合并,但字符串条件则只支持一次。

关于ThinkPHP中where()方法的使用,本文就介绍这么多,希望对您有所帮助,谢谢!

相关推荐:

ThinkPHP中redirect用法分析

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal