(转)ThinkPHP Where 条件中使用表达式

转之--http://www.cnblogs.com/martin1009/archive/2012/08/24/2653718.html

Where 条件表达式格式为:

$map[‘字段名‘]  = array(‘表达式‘, ‘操作条件‘);

其中 $map 是一个普通的数组变量,可以根据自己需求而命名。上述格式中的表达式实际是运算符的意义:

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

补充说明

  • 同 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 的数据数组,文章点击数+1
$data[‘id‘] = 10;
$data[‘counter‘] = array(‘exp‘,‘counter+1‘);

// 根据条件保存修改的数据
$User->save($data);
时间: 2024-08-28 08:09:13

(转)ThinkPHP Where 条件中使用表达式的相关文章

ThinkPHP Where 条件中使用表达式

Where 条件表达式格式为: $map['字段名'] = array('表达式', '操作条件'); 其中 $map 是一个普通的数组变量,可以根据自己需求而命名.上述格式中的表达式实际是运算符的意义: ThinkPHP运算符 与 SQL运算符 对照表 TP运算符 SQL运算符 例子 实际查询条件 eq = $map['id'] = array('eq',100); 等效于:$map['id'] = 100; neq != $map['id'] = array('neq',100); id !

JAVA性能调优-在循环条件中不要使用表达式

1.JAVA性能调优-在循环条件中不要使用表达式 我们在学习JAVA性能调优的时候,经常能看到这一的一段话:在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快. import java.util.vector; class cel { void method(vector vector) { for (int i= 0; i < vector.size (); i++)  //violation ; //... } } 更正:

“中序表达式”转换为“前序表达式”、“后序表达式”

首先看下面所示表格: 中序表达式 2*3/(2-1)+3*(4-1) 前序表达式 +/*23-21*3-41 后序表达式 23*21-/341-*+ 中序表达式对我们而言是很直观的(我们平时接触的就是这个),但计算机处理起来比较麻烦(括号.优先级之类的),前序和后序表达式中没有括号,而且在计算中只需单向扫描,不需要考虑运算符的优先级. 以前序表达式“+/*23-21*3-41”为例,从右往左,先取出两个操作数“1”.“4”和一个运算符“-”,计算“4-1”,将结果3回填到字符串中,现在字符串变为

JSP中EL表达式的应用以及常用的方法

EL表达式      1.EL简介 1)语法结构        ${expression} 2)[]与.运算符      EL 提供.和[]两种运算符来存取数据.      当要存取的属性名称中包含一些特殊字符,如.或?等并非字母或数字的符号,就一定要使用 []. 例如:          ${user.My-Name}应当改为${user["My-Name"] }      如果要动态取值时,就可以用[]来做,而.无法做到动态取值.例如:          ${sessionScop

第86讲:Scala中For表达式的生成器、定义和过滤器

今天我们来看一下For表达式中的生成器,定义和过滤等内容. 让我们来看下代码 def main(args:Array[String]){     val lauren = Persons("Lauren",false)    val rocky = Persons("Rocky",true)    val vivian = Persons("Vivian",false,lauren,rocky)    val persons = List(lau

Scala深入浅出实战经典《第86讲:Scala中For表达式的生成器、定义和过滤器》笔记

第86讲:Scala中For表达式的生成器.定义和过滤器 Goal: For的生成器.定义.过滤器 Gains: 生成器:从集合中取出每个元素,for语句中可以有多个生成器 过滤器: 循环满足的条件 More: 把实例代码跑一遍~ ------------------------------------------------------------------------------------ 信息来源于 DT大数据梦工厂微信公众账号:DT_Spark DT大数据梦工厂scala的所有视频.

Kotlin中when表达式的使用:超强的switch(KAD 13)

作者:Antonio Leiva 时间:Feb 23, 2017 原文链接:https://antonioleiva.com/when-expression-kotlin/ 在Java(特别是Java 6)中,switch表达式有很多的限制.除了针对短类型,它基本不能干其他事情. 然而,Kotlin中when表达式能够干你想用switch干的每件事,甚至更多. 实际上,在你的代码中,你可以用when替换复杂的if/else语句. Kotlin的when表达式 开始,你可以像switch那样使用w

Thinkphp 查询条件 and 和 or同时使用即复合查询

        thinkphp 3.2快捷查询OR查询&分割表示AND查询讲解         快捷查询方式是一种多字段查询的简化写法,可以进一步简化查询条件的写法,在多个字段之间用|分割表示OR查询,用&分割表示AND查询,可以实现下面的查询,例如:         一.不同字段相同的查询条件 $User = M("User"); // 实例化User对象             $map['name|title'] = 'thinkphp';           

中序表达式转后序表式式

中序表达式转后序表式式: 将中序表达式所有括号补全,然后将所有运算符向右移出无匹配的第一个右括号,去掉括号即为后序表式式 举例: 原式:a+b*(c+d/e) 补全括号:(a+(b*(c+(d/e)))) 操作符右移:(a(b(c(de)/)+)*)+ 去掉括号:abcde/+*+ 中序表达式转前序表式式: 将中序表达式所有括号补全,然后将所有运算符向左移出无匹配的第一个左括号,去掉括号即为前序表式式 举例: 原式:a+b*(c+d/e) 补全括号:(a+(b*(c+(d/e)))) 操作符右移