ThinkPHP运算符 与 SQL运算符 对比表[通俗易懂]

ThinkPHP运算符 与 SQL运算符 对比表

大家好,又见面了,我是全栈君。

ThinkPHP运算符 与 SQL运算符 对比表

TP运算符

SQL运算符

样例

实际查询条件

eq

=

$map[‘id’] = array(‘eq’,100);

等效于:$map[‘id’] = 100;

neq

!=

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

id != 100

gt

>

$map[‘id’] = array(‘gt’,100);

id > 100

egt

>=

$map[‘id’] = array(‘egt’,100);

id >= 100

lt

<

$map[‘id’] = array(‘lt’,100);

id < 100

elt

<=

$map[‘id’] = array(‘elt’,100);

id <= 100

like

like

$map<‘username’> = array(‘like’,’Admin%’);

username like ‘Admin%’

between

between and

$map[‘id’] = array(‘between’,’1,8′);

id BETWEEN 1 AND 8

not between

not between and

$map[‘id’] = array(‘not between’,’1,8′);

id NOT BETWEEN 1 AND 8

in

in

$map[‘id’] = array(‘in’,’1,5,8′);

id in(1,5,8)

not in

not in

$map[‘id’] = array(‘not in’,’1,5,8′);

id not in(1,5,8)

and(默认)

and

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

(id > 1) AND (id < 10)

or

or

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

(id > 3) OR (id < 10)

xor(异或)

xor

两个输入中仅仅有一个是true时。结果为true,否则为false,样例略。

1 xor 1 = 0

exp

综合表达式

$map[‘id’] = array(‘exp’,’in(1,3,8)’);

$map[‘id’] = array(‘in’,’1,3,8′);

or

不同字段 or 

$map[‘id’] = ‘8’;

$map[‘pid’] = ’10’;

$map[‘_logic’] = ‘OR’;

‘id’=8 AND ‘pid’=10

 

 

补充说明

· 同 SQL 一样,ThinkPHP运算符不区分大写和小写。eq 与 EQ 一样。

· between、 in 条件支持字符串或者数组,即以下两种写法是等效的:

$map[‘id’]  = array(‘not in’,’1,5,8′);

$map[‘id’]  = array(‘not in’,array(‘1′,’5′,’8’));

· 

exp 表达式

上表中的 exp 不是一个运算符。而是一个综合表达式以支持更复杂的条件设置。

exp 的操作条件不会被当成字符串。能够使用不论什么 SQL 支持的语法。包含使用函数和字段名称。

exp 不仅用于 where 条件,也能够用于数据更新,如:

$Dao = M(“Article”);

 

// 构建 save 的数据数组,文章PV数+1

$data[‘id’] = 10;$data[‘counter’] = array(‘exp’,’counter+1‘);

 

// 依据条件保存改动的数据

$User->save($data);

 

ThinkPHP Where 条件中使用表达式

原文出自http://www.cnblogs.com/martin1009/archive/2012/08/24/2653718.html

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116285.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 滑动窗口算法学习

    滑动窗口算法学习最近做了几道有关滑动窗口的算法,在此总结一下。滑动窗口就像描述的那样,可以理解成是一个会滑动的窗口,每次记录下窗口的状态,再找出符合条件的适合的窗口可以使用滑动窗口来减少时间复杂度经典滑动窗口题目给一组大小为n的整数数组,计算长度为k的子数组的最大值比如:数组{1,2,3,4,5,7,6,1,8},k=2,那么最终结果应该是7+6=13最大。最简单的是使用两层遍历,通过所有情况找…

    2025年8月6日
    4
  • hibernate的hql语句批量删除

    hibernate的hql语句批量删除hibernate使用hql语句,根据条件进行批量删除操作;比如:1.给方法传递一个参数,我传递的是userid2.hql语句编写,根据userid进行删除(我使用了拼接userid的方式进行条件拼接)3.通过createQuery(hql),先到数据库查询满足条件的数据。然后通过executeUpdata()方法进行了批量更新删除操作;具体的代码如下:publicvoidemptycartItm(Integeruserid){//根据条件批量删除Stringhql=“delete

    2022年6月16日
    52
  • 预制发票,相关屏幕增强及bapi 增强

    预制发票,相关屏幕增强及bapi 增强MIRO:需要对屏幕增强,实现可以输入xref1,xref2.如下图:图中,参考代码1和参考代码2都是通过隐式增强放出来的,具体操作过程请查看链接:https://blogs.sap.com/2020/11/04/xref1-xref2-xref3-in-miro-the-ultimate-solution/在下列程序中,写隐式增强相关表增强:之所以在这么多表中增强,是为了后面过账的时候,能把参考码传递给财务凭证2.上面…

    2022年7月24日
    22
  • phpstorm2018激活码_一键无痕视频无需激活ios

    phpstorm2018激活码_一键无痕视频无需激活iosPhpStorm激活码最新破解教程,Mac版激活至2299年,PhpStorm激活码2021.3.3

    2022年4月20日
    221
  • 使用matlab对图像进行二值化处理

    使用matlab对图像进行二值化处理图像二值化就是将图像上的像素点的灰度值设置为 0 或 255 也就是将整个图像呈现出明显的黑白效果的过程 A imread D A thresh graythresh A 确定二值化阈值 B im2bw A thresh 对图像二值化

    2025年8月26日
    3
  • spring boot打jar包、war包的区别

    spring boot打jar包、war包的区别maven打包项目的打包类型:pom、jar、warpacking默认是jar类型,<packaging>pom</packaging>———>父类型都为pom类型<packaging>jar</packaging>———>内部调用或者是作服务使用<packa…

    2022年5月15日
    95

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号