ThinkPHP3快速入门教程三:查询语言
一、查询语言简介:
ThinkPHP内置了非常灵活的查询方法,可以快速的进行数据查询操作,查询条件可以用于读取、更新和删除等操作,主要涉及到where方法等连贯相关方法操作即可,
此框架查询系统可以解决不同数据库的差异性,因些我们把框架的这一查询方式称之为查询语言。使其查询操作更加简单易懂。
二、查询方式:
ThinkPHP可以支持直接使用字符串作为查询条件,但是大多数情况推荐使用索引数组或者对象来作为查询条件,因为会更加安全。
1、使用字符串作为查询条件(最传统的方式,但是安全性不高),例如:
$User = M(“User”); //实例化User对象
$User -> where(‘type=1 AND status=1’) -> select();
生成SQL语句:SELECT *FORM think_user WHERE type=1 AND status=1;
注意:采用字符串查询的时候,我们可以配合使用新版提供的字符串条件的安全预处理机制。
2、使用数组作为查询条件
这种方式是最常用的查询方式,例如:
$User = M(“User”); //实例化User对象
$condition[‘name’] =’thinkphp’;
$condition[‘status’] = 1;
//把查询条件传入查询方法
$user -> where($condition) -> select();
//生成的SQL语句
SELECT*FORM think_user WHERE ‘name’ = ‘thinkphp’ AND status=1;
如果进行多字段查询,那么字段之间的默认逻辑关系是逻辑与AND,但是用下面的规则可以更改默认的逻辑判断,通过使用_logic定义查询逻辑:
$User = M(“user”); //实例化User对象
$condition[‘name’] = ‘thinkphp’;
$condition[‘account’] = ‘thinkphp’;
$condition[‘_logic’] = ‘OR’;
//把查询条件传入查询方法
$User -> Where($condition)->select();
生成的SQL语句:SELECT * FROM think_user WHERE `name`='thinkphp' OR `account`='thinkphp';
3、使用对象方式来查询
这里以stdClass内置对象为例:
$User = M(“User”); //实例化User对象
//定义查询条件
$condition = new stdClass();
$codition -> name= ’thinkphp’;
$codition -> status = 1;
$User -> where($condition) ->select();
生成的SQL语句:SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1
使用对象方式和数组方式来查询数据是一样的,大多数情况下,建议使用数组方式更加高效。
三、表达式查询:
ThinkPHP查询语言的精髓,查询表达式的使用格式:
$map[‘字段名’] = array(‘表达式’,‘查询条件’);
表达式不分大小写,支持的查询表达式有下面几种,分别表示的含义是:
示例如下:
EQ:等于(=)
例如:
$map[‘id’] = array(‘eq’,100);
$map[‘id’] = 100;//和上面查询等效
查询条件为: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
[NOT]LIKE:同sql的LIKE
例如:
$map[‘name’] = array(‘like’,’thinkphp%’);
查询条件:name like ‘thinkphp%’
如果配置了DB_LIKE_FIEKLDS参数的话,某些字段也会自动进行模糊查询。例如设置了:
‘DB_LIKE_FIELDS’参数的话,某些字段也会自动进行模糊查询。例如设置了:
‘DB_LIKE_FIELDS’ => ‘title|content’;的话,使用$map[‘title’]=’thinkphp%’;
查询条件就会变成title like ‘%thinkphp%’
支持数组方式,例如:
$map[‘a’] = array(‘like’,array(‘%thinkphp%’,’%tp’),’OR’);
$map[‘b’] = array(‘notlike’,array(‘%thinkphp%’,’%tp’),’AND’);
生成的查询条件:
(a like ‘%thinkphp%’ OR a like ‘%tp’) AND (b not like ‘%thinkphp%’ AND like ‘%tp’)
[NOT] BETWEEN : 同sql的[not]between,查询条件支持字符串或者数组,例如:
$map[‘id’] = array(‘between’,’1,8’);
$map[‘id’] = array(‘between’,array(‘1’,’8’)); //和上行语句等效
查询条件就变成id BETWEEN 1 AND 8
[NOT]IN:同sql的[NOT]的in,查询条件支持字符串或者数组,例如:
$map[‘id’] = array(‘not in’,’1,5,8’);
$map[‘id’] = array(‘not in’,array(‘1’,’5’,’8’)); //和上条语句等效
查询条件:id NOT IN(1,5,8)
EXP:表达式,支持更复杂的查询情况
例如:$map[‘id’] = array(‘in’,’1,3,8’);
可改成:
$map[‘id’] = array(‘exp’,’IN(1,3,8)’);
Exp查询的条件不会被当成字符串,所以后面的查询条件可以使用任何SQL支持的语法,
包括使用函数和字段名称。查询表达式不仅可用于查询条件,也可以用于数据更新,例如:
$User = M(“User”); //实例化User对象
//要修改的数据对象属性赋值
$data[‘name’] = ‘ThinkPHP’;
$data[‘score’] = array(‘exp’,’score+1’); //用户的积分加1
$User->where(‘id=5’)->save($data); //根据条件保存修改的数据
四、快捷查询:
3.0版本开始,增加了快捷查询方式,可以进一步简化查询条件的写法,例如:
1、实现不同字段相同的查询条件
$User = M(“User”); //实例化User对象
$map[‘name|title’] = ‘thinkphp’;
//把查询条件传入查询方法
$User->where($map)->select();
查询条件:name= ’thinkphp’ OR title = ‘thinkphp’
2、实现不同字段不同的查询条件
$User = M(“user”); //实例化User对象
$map[‘status&title’]=array(‘1’, ’thinkphp’, ’_multi’=>true);
//把查询条件传入查询方法
$User -> where($map) -> select();
‘_multi’ => true 必须加在数组的最后,表示当前是多条件匹配,这样查询条件就变成:status= 1 AND title= ’thinkphp’
查询字段支持最多的,例如:
$map['status&score&title'] =array('1',array('gt','0'),'thinkphp','_multi'=>true);
查询条件变成:status= 1 AND score>0 AND title = ‘thinkphp’
注意:快捷查询方式中”|”和”&”不能同时使用。
五、区间查询:
ThinkPHP支持对某个字段的区间查询,例如:
$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)
区间查询的条件可以支持普通查询的所有表达式,也就是说类似LIKE、GT和EXP这样的表达式都可以支持。
另外区间查询还可以支持更多的条件,只要是针对一个字段的条件都可以写到一起,例如:
$map[‘name’] = array(array(‘like’,’%a%’),array(‘like’,’%b%’),array(%c%),’ThinkPHP’,’or’);
查询条件:
(‘name’ LIKE ‘%a%’)OR(‘name’ like ‘%b%’) OR (‘name’ like ‘%c%’) or(‘ThinkPHP’)
六、组合查询:
七、统计查询:
八、SQL查询:
九、动态查询:
十、子查询:
十一、总结:
ThinkPHP3快速入门教程三:查询语言的更多相关文章
- ThinkPHP3快速入门教程二:数据CURD
CURD(创建[Create].更新[Updata].读取[Read].删除[Delete]),定义了用于处理数据的基本原子操作. CURD在具体的应用中并非一定使用create.updata.rea ...
- ThinkPHP3快速入门教程-:基础
一.ThinkPHP的认识: ThinkPHP是一个快速.简单的基于MVC和面向对象的轻量级PHP开发框架. 二.下载后的目录结构: ├─ThinkPHP.php 框架入口文件 ├─Commo ...
- Jmeter 快速入门教程(三-3) -- 使用参数化
参数化:简单的来理解一下,我们录制了一个脚本,这个脚本中有登录操作,需要输入用户名和密码,假如系统不允许相同的用户名和密码同时登录,或者想更好的模拟多个用户来登录系统. 这个时候就需要对用户名和密码进 ...
- Jmeter 快速入门教程(三-2) -- 设置集结点
集合点:简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点, 还拿那个用户和密码的地方,每到输入用户 ...
- Jmeter 快速入门教程(三-1) --添加响应断言(即loadrunner中所指的检查点)
[版权所有: whoistester.com & jmeter.cf] 上一节课,我们创建了一个测试场景,并进行了少量vuser的负载测试. 有时候我们执行了测试,但是发现并不是所有事务都执行 ...
- 3.Jmeter 快速入门教程(三-1) --添加响应断言(即loadrunner中所指的检查点)
上一节课,我们创建了一个测试场景,并进行了少量vuser的负载测试. 有时候我们执行了测试,但是发现并不是所有事务都执行成功了. 那是因为我们只是发起了测试,但并没有对每次请求测试的返回作校验. 所以 ...
- 4.Jmeter 快速入门教程(三-2) -- 设置集结点
集合点:简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点, 还拿那个用户和密码的地方,每到输入用户 ...
- ThinkPHP3.1快速入门教程
ThinkPHP3.1快速入门教程 http://www.thinkphp.cn/info/155.html ------------------------------------------- ...
- 专为设计师而写的GitHub快速入门教程
专为设计师而写的GitHub快速入门教程 来源: 伯乐在线 作者:Kevin Li 原文出处: Kevin Li 在互联网行业工作的想必都多多少少听说过GitHub的大名,除了是最大的开源项目 ...
随机推荐
- 使用karma测试平时写的小demo(arguments为例)
有人说前端自动化测试非常困难,我觉得确实如此.在项目中,我个人也不放心写的测试,还是要手动测试.但是我们平时写demo学习时,完全可以使用自动化测试. 传统demo 1,新建一个html 2,写入js ...
- iOS开发之ImageView复用实现图片无限轮播
在上篇博客中iOS开发之多图片无缝滚动组件封装与使用给出了图片无限轮播的实现方案之一,下面在给出另一种解决方案.今天博客中要说的就是在ScrollView上贴两个ImageView, 把ImageVi ...
- 前端编码风格规范之 HTML 规范
HTML 规范 文档类型 推荐使用 HTML5 的文档类型申明: <!DOCTYPE html>. (建议使用 text/html 格式的 HTML.避免使用 XHTML.XHTML 以及 ...
- YII 的源码分析(二)
上一篇简单分析了一下yii的流程,从创建一个应用,到屏幕上输出结果.这一次我来一个稍复杂一点的,重点在输出上,不再是简单的一行"hello world",而是要经过view(视图) ...
- ASP.NET MVC Ajax.ActionLink 简单用法
ASP.NET MVC 项目中,如何使用类似于 iframe 的效果呢?或者说 Ajax 局部刷新,比如下面操作: 我们想要的效果是,点击 About 链接,页面不刷新(地址栏不变),然后下面的内容进 ...
- 关于C#静态变量初始化问题
关于这个静态变量,平时自己没有太认真的去认识.最近调项目的bug,让我重新认识了静态变量的特点. 其实,我们一直都在说:静态变量只在类第一次初始化的时候进行初始化,以后都不初始化. 很简单的一句话,但 ...
- PHP之时间处理
面试的时候有一道题是这样的:封装一个函数实现,给你一个时间,输出这个时间的对应的这一天是星期几,其实无非就是一些时间格式的处理: date_default_timezone_set('PRC'); / ...
- C语言分割字符串
最近在做一道C语言题目的时候需要用到分割字符串,本来想自己手写的,也不会很麻烦,但想到其他语言都有分割字符串的库函数,C语言怎么会没有呢?所以,在网上搜了一搜,果然有这样的函数,还是很好用的,在此总结 ...
- EF中的实体类型【Types of Entity in Entity】(EF基础系列篇8)
We created EDM for existing database in the previous section. As you have learned in the previous se ...
- 【翻译】设计模式学习系列1---【Design Patterns Simplified: Part 1【设计模式简述:第一部分】】
原文链接:http://www.c-sharpcorner.com/UploadFile/19b1bd/design-patterns-simplified-part1/ Design Pattern ...