码迷,mamicode.com
首页 > 数据库 > 详细

第 39 章 ThinkPHP--SQL 查询语句

时间:2015-10-02 22:24:29      阅读:266      评论:0      收藏:0      [点我收藏+]

标签:

将学习 ThinkPHP 中对于 SQL 查询语句,包含了基本的查询方式、表达式查询、快捷查询、区间查询、组合查询、统计查询、SQL 查询、动态查询和子查询。

一.查询方式 ThinkPHP 提供了三种基本的查询方式:字符串条件查询、索引数组条件查询和对象条件查询。

在大多数情况下,推荐使用索引数组和对象方式作为查询条件,因为会更加安全

 

1.使用字符串作为条件查询

//字符串作为条件查询
$user = M(User);
var_dump($user->where(id=1 AND user="蜡笔小新")->select());
//最终生成的 SQL 语句
SELECT * FROM `think_user` WHERE ( id=1 AND user="蜡笔小新" )

PS:where 查询方法里面只要包含条件即可,多个条件加上 AND 等连接符即可。我们会 在 SQL 连贯操作详细学习。

 

2.使用索引数组作为查询条件

//索引数组作为条件查询
$user = M(User);
$condition[id] = 1;
$condition[user] = 蜡笔小新;
var_dump($user->where($condition)->select());
//最终生成的 SQL 语句
SELECT * FROM `think_user` WHERE ( `id` = 1 ) AND ( `user` = 蜡笔小 )

PS:索引数组查询的默认逻辑关系是 AND,如果想改变为 OR,可以使用_logic 定义查 询逻辑。

基于上面的代码增加如下一行:

 $condition[_logic] = OR;     //将默认 AND 改成 OR

 

3.使用对象方式来查询

//对象作为条件查询
$user = M(User);
$condition = new \stdClass();
$condition->id = 1;
$condition->user = 蜡笔小新;
var_dump($user->where($condition)->select());
//最终生成的 SQL 语句
SELECT * FROM `think_user` WHERE ( `id` = 1 ) AND ( `user` = 蜡笔小 )

PS:stdClass 类是 PHP 内置的类,可以理解为一个空类,在这里可以理解为把条件的 字段作为成员保存到 stdClass 类里。

而这里的‘\‘是将命名空间设置为根目录,否则会导 致当前目录找不到此类。使用对象和数组查询,效果是一样的,可以互换。在大多数情况下, ThinkPHP 推荐使用数组形式更加高效。

 

二.表达式查询

对于那些要实现模糊判断的查询,比如大于、等于、小于之类的SQL查询,可以使用表 达式查询方式。 查询表达式格式:$map[‘字段名‘] = array(‘表达式‘,‘查询条件‘);

表达式查询表 表达式 含义 EQ 等于(=)    NEQ 不等于(<>)    GT 大于(>)    EGT 大于等于(>=)    LT 小于(<)    ELT 小于等于(<=)    [NOT]LIKE 模糊查询     [NOT] BETWEEN (不在)区间查询     [NOT] IN (不在)IN查询     EXP 表达式查询,支持SQL语法

PS:表达式不区分大小写。

//EQ:等于(=)
$map[id] = array(eq, 1); //where 为 id=1
//NEQ:不等于(<>)
$map[id] = array(neq, 1); //where 为 id<>1
//GT:大于(>)
$map[id] = array(gt, 1); //where 为 id>1
//EGT:大于等于(>=)
$map[id] = array(egt, 1); //where 为 id>=1
//LT:小于(<)
$map[id] = array(lt, 1); //where 为 id<1
//ELT:小于等于(<=)
$map[id] = array(elt, 1); //where 为 id<=1
//[NOT]LIKE:模糊查询
$map[user] = array(like, %小%); //where 为 like %小%
//[NOT]LIKE:模糊查询
$map[user] = array(notlike, %小%); //where 为 not like %小%
//[NOT]LIKE:模糊查询的数组方式
$map[user] = array(like, array(%小%, %蜡%), AND);
//生成的 SQL
SELECT * FROM `think_user` WHERE ( (`user` LIKE %小% AND `user`
LIKE %蜡%) )
//[NOT] BETWEEN:区间查询
$map[id] = array(between,1,3);
//where 为`id` BETWEEN ‘1‘ AND ‘2‘
//同上等效
$map[id] = array(between,array(1,3));
//[NOT] BETWEEN:区间查询
$map[id] = array(not between,1,3);
//where 为`id` NOT BETWEEN ‘1‘ AND ‘2‘
//[NOT] IN:区间查询
$map[id] = array(in,1,2,4);
//where 为`id` IN (‘1‘,‘2‘,‘4‘)
//[NOT] IN:区间查询
$map[id] = array(not in,1,2,4);
//where 为`id` NOT IN (‘1‘,‘2‘,‘4‘)
//EXP:自定义
$map[id] = array(exp,in (1,2,4));
//where 为`id` NOT IN (‘1‘,‘2‘,‘4‘)
PS:使用 exp 自定义在第二个参数直接写 where 语句即可
//EXP:自定义增加 OR 语句
$map[id] = array(exp, =1);
$map[user] = array(exp, ="蜡笔小新");
$map[_logic] = OR;
//WHERE 为( (`id` =1) ) OR ( (`user` ="蜡笔小新") )

 

三.快捷查询

快捷查询方式是一种多字段查询的简化写法,在多个字段之间用‘|‘隔开表示OR,用‘&‘ 隔开表示 AND。

1.不同字段相同查询条件
//使用相同查询条件
$user = M(User);
$map[user|eemail] = a; //‘|‘换成‘&‘变成AND
var_dump($user->where($map)->select());
2.不同字段不同查询条件
//使用不同查询条件
$user = M(User);
$map[id&user] = array(1,蜡笔小新,_multi=>true);
var_dump($user->where($map)->select());
PS:设置_multitrue,是为了让 id 对应 1,让 user 对应蜡笔小新,否则就
会出现 id 对应了 1 还要对应蜡笔小新的情况。而且,这设置要在放在数组最后。
//支持使用表达式结合快捷查询
$user = M(User);
$map[id&user] = array(array(gt, 0),蜡笔小新,_multi=>true);
var_dump($user->where($map)->select());

 

四.区间查询

ThinkPHP 支持对某个字段的区间查询。

//区间查询
$user = M(User);
$map[id] = array(array(gt, 1), array(lt, 4));
var_dump($user->where($map)->select());
//第三个参数设置逻辑OR
$user = M(User);
$map[id] = array(array(gt, 1), array(lt, 4), OR);
var_dump($user->where($map)->select());

 

五.组合查询

组合查询是基于索引数组查询方式的一个扩展性查询,添加了字符串查询(_string)、复 合查询(_complex)、请求字符串查询(_query),由于采用的是索引数组,重复的会被覆盖。

//字符串查询(_string)
$user = M(User);
$map[id] = array(eq, 1);
$map[_string] =user="蜡笔小新" AND email="xiaoxin@163.com";
var_dump($user->where($map)->select());
//请求字符串查询(_query)
$user = M(User);
$map[id] = array(eq, 1);
$map[_query] =user=蜡笔小新&email=xiaoxin@163.com&_logic=OR;
var_dump($user->where($map)->select());
PS:这种方式是 URL 方式,不需要加引号。
//复合查询(_complex)
$user = M(User);
$where[user] = array(like, %小%);
$where[id] = 1;
$where[_logic] = OR;
$map[_complex] = $where;
$map[id] = 3;
$map[_logic] = OR;
var_dump($user->where($map)->select());
PS:复合查询可以构建更加复杂的查询,这里 id=1 或者 id=3 可以构建实现。

 

六.统计查询

ThinkPHP 提供了一些数据统计查询的方法。

//数据总条数
$user = M(User);
var_dump($user->count());
//字段总条数,遇到NULL不统计
$user = M(User);
var_dump($user->count(email));
//最大值
$user = M(User);
var_dump($user->max(id));
//最小值
$user = M(User);
var_dump($user->min(id));
//平均值
$user = M(User);
var_dump($user->avg(id));
//求总和
$user = M(User);
var_dump($user->sum(id));

 

七.动态查询

借助 PHP5 语言的特性,ThinkPHP 实现了动态查询。

1.getBy 动态查询
//查找email=xiaoin@163.com的数据
$user = M(User);
var_dump($user->getByemail(xiaoxin@163.com));
2.getFieldBy 动态查询
//通过user得到相对应id值
$user = M(User);
var_dump($user->getFieldByUser(路飞, id));

 

八.SQL 查询

ThinkPHP 支持原生 SQL 查询。
1.query 读取
//查询结果集,如果采用分布式读写分离,则始终在读服务器执行
$user = M(User);
var_dump($user->query(SELECT * FROM think_user));
2.execute写入
//更新和写入,如果采用分布式读写分离,则始终在写服务器执行
$user = M(User);
var_dump($user->execute(UPDATE think_user set user="蜡笔大新" WHERE
id=1));

PS:由于子查询用了不少连贯操作,我们会在连贯操作讲解。

第 39 章 ThinkPHP--SQL 查询语句

标签:

原文地址:http://www.cnblogs.com/yu520zhong/p/4852756.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!