thinkphp 表达式查询

上面的查询条件仅仅是一个简单的相等判断,可以使用查询表达式支持更多的SQL查询语法,也是ThinkPHP查询语言的精髓,查询表达式的使用格式:

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

大理石平台规格

表达式不分大小写,支持的查询表达式有下面几种,分别表示的含义是:

表达式 含义 协助记忆
EQ 等于(=) equal
NEQ 不等于(<>) not equal
GT 大于(>) greater
EGT 大于等于(>=) equal or greater
LT 小于(<) less than
ELT 小于等于(<=) equal or less than
LIKE 模糊查询  
[NOT] BETWEEN (不在)区间查询  
[NOT] IN (不在)IN 查询  
EXP 表达式查询,支持SQL语法 expression

表达式查询的用法示例如下:

EQ :等于(=)

例如:

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

和下面的查询等效

  1. $map[‘id‘] = 100;

表示的查询条件就是 id = 100

NEQ: 不等于(<>)

例如:

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

表示的查询条件就是 id <> 100

GT:大于(>)

例如:

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

表示的查询条件就是 id > 100

EGT:大于等于(>=)

例如:

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

表示的查询条件就是 id >= 100

LT:小于(<)

例如:

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

表示的查询条件就是 id < 100

ELT: 小于等于(<=)

例如:

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

表示的查询条件就是 id <= 100

[NOT] LIKE: 同sql的LIKE

例如:

  1. $map[‘name‘] = array(‘like‘,‘thinkphp%‘);

查询条件就变成 name like ‘thinkphp%‘ 如果配置了DB_LIKE_FIELDS参数的话,某些字段也会自动进行模糊查询。例如设置了:

  1. ‘DB_LIKE_FIELDS‘=>‘title|content‘

的话,使用

  1. $map[‘title‘] = ‘thinkphp‘;

查询条件就会变成 title like ‘%thinkphp%‘ 支持数组方式,例如

  1. $map[‘a‘] =array(‘like‘,array(‘%thinkphp%‘,‘%tp‘),‘OR‘);
  2. $map[‘b‘] =array(‘notlike‘,array(‘%thinkphp%‘,‘%tp‘),‘AND‘);

生成的查询条件就是:

  1. (a like ‘%thinkphp%‘ OR a like ‘%tp‘) AND (b not like ‘%thinkphp%‘ AND b not like ‘%tp‘)

[NOT] BETWEEN :同sql的[not] between

查询条件支持字符串或者数组,例如:

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

和下面的等效:

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

查询条件就变成 id BETWEEN 1 AND 8

[NOT] IN: 同sql的[not] in

查询条件支持字符串或者数组,例如:

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

和下面的等效:

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

查询条件就变成 id NOT IN (1,5, 8)

EXP:表达式

支持更复杂的查询情况 例如:

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

可以改成:

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

exp查询的条件不会被当成字符串,所以后面的查询条件可以使用任何SQL支持的语法,包括使用函数和字段名称。查询表达式不仅可用于查询条件,也可以用于数据更新,例如:

  1. $User = M("User"); // 实例化User对象
  2. // 要修改的数据对象属性赋值
  3. $data[‘name‘] = ‘ThinkPHP‘;
  4. $data[‘score‘] = array(‘exp‘,‘score+1‘);// 用户的积分加1
  5. $User->where(‘id=5‘)->save($data); // 根据条件保存修改的数据

原文地址:https://www.cnblogs.com/furuihua/p/11811115.html

时间: 2024-08-03 04:45:43

thinkphp 表达式查询的相关文章

thinkphp的普通查询与表达式查询

一.普通查询方式 a.字符串:$arr=$m->where("sex=0 and username='gege'")->find();//字符串需要加引号 b.数组 $data['sex']=0; $data['username']='gege'; $arr=$m->where($data)->find();//传上一个数组进行查询,这种方式默认是and(并且)的关系 注意:如果使用or关系,需要添加数组值 $data['sex']=0; $data['user

CRL快速开发框架系列教程二(基于Lambda表达式查询)

本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框架系列教程四(删除数据) CRL快速开发框架系列教程五(使用缓存) CRL快速开发框架系列教程六(分布式缓存解决方案) CRL快速开发框架系列教程七(使用事务) CRL快速开发框架系列教程八(使用CRL.Package) CRL快速开发框架系列教程九(导入/导出数据) CRL快速开发框架系列教程十(

ThinkPHP视图查询详解

ThinkPHP视图查询详解 参考http://www.jb51.net/article/51674.htm 这篇文章主要介绍了ThinkPHP视图查询,需要的朋友可以参考下 ThinkPHP提供的视图查询应用功能十分强大,用户利用视图查询功能可以将多个数据表的字段内容按需要进行指定和筛选,组织成一个基于这些数据表的视图模型,然后就可以通过该模型直接进行多表联合查询,非常方便和简单. 例如在项目中,我们定义有三个表: user          用户基础表,user_info   用户详细信息表

执行多个lanmada表达式查询

/// <summary> /// 执行多个lanmada表达式查询 /// </summary> /// <typeparam name="T">类型</typeparam> /// <param name="row">每页条数</param> /// <param name="page">当前页</param> /// <param name

thinkphp条件查询和模糊查询的一些方法

1 #文章管理 2 public function adminArticle(){ 3 $adminArticle=M("article"); 4 $arr_seach=$this->seach($adminArticle,10,"now desc","");//参数格式seach($db,$num,$order,$where) 5 ##按最早排序 6 if([email protected]empty($_POST['time'])){

thinkphp 快捷查询

快捷查询方式是一种多字段查询的简化写法,可以进一步简化查询条件的写法,在多个字段之间用|分割表示OR查询,用&分割表示AND查询,可以实现下面的查询,例如: 大理石平台价格 一.不同字段相同的查询条件 $User = M("User"); // 实例化User对象 $map['name|title'] = 'thinkphp'; // 把查询条件传入查询方法 $User->where($map)->select(); 上面的查询其实可以等效于 $User = M(&

thinkphp中查询数据库具体的使用方法

thinkphp中数据操作方法的使用: 一.where()条件 $model->where(条件值);    //条件值就是sql语句where后边的结果值 $goods->where('goods_price>1000 and goods_name like "诺%" ');    //sql语句where后边的信息都可以作为where方法的参数 $info=$goods->select(); 二.limit()限制条件 $model->limit(数字

ThinkPHP数据查询与添加语句

在ThinkPHP框架中实现数据的查询操作 1 function ShowAll() 2 { 3 //Model:数据库中每张表对应一个模型 4 //类名是表名,类里面的成员变量是列名 5 //把一张表对应一个类,其中一条数据对应一个对象 6 //如果我们对该表没有特殊操作的话可以不用建立该模型 7 8 //实例化MODEL类 9 $info = new \Home\Model\InfoModel(); 10 var_dump($info); 11 12 //用D方法 13 $car = D("

总结thinkphp快捷查询getBy、getField、getFieldBy用法及场景

thinkphp作为国内现阶段最成熟的框架:没有之一: 不得不说是有好些特别方便的方法的: 然而如果初接触thinkphp的时候难免会被搞的有点迷茫: for example这些: getBy getField getFieldBy 我曾在相当一段时间内都用的迷迷糊糊的: 直到后来把它们总结如下: 咱先虚拟一张表出来 +----+--------+--------------+| id | name   | avatar              |+----+--------+--------