博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
thinkPHP--SQL查询
阅读量:5113 次
发布时间:2019-06-13

本文共 5085 字,大约阅读时间需要 16 分钟。

一.查询方式 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');//生成的 SQLSELECT * 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'; //'|'换成'&'变成ANDvar_dump($user->where($map)->select());2.不同字段不同查询条件//使用不同查询条件$user = M('User');$map['id&user'] = array(1,'蜡笔小新','_multi'=>true);var_dump($user->where($map)->select());PS:设置'_multi'为 true,是为了让 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="蜡笔大新" WHEREid=1'));

转载于:https://www.cnblogs.com/The-second/p/6214914.html

你可能感兴趣的文章
IOS第17天(3,Quartz2D画板和画线)
查看>>
pair的例子
查看>>
前端框架性能对比
查看>>
@property中 retain 详解
查看>>
java8 stream初试,map排序,list去重,统计重复元素个数,获取map的key集合和value集合...
查看>>
Python爬虫个人记录(四)利用Python在豆瓣上写一篇日记
查看>>
jdk8 Function
查看>>
第二次作业
查看>>
迷茫中的自己
查看>>
burp suite 的intruder 四种攻击方式
查看>>
机器学习----人脸对齐的算法-ASM.AAM..CLM.SDM
查看>>
自定义文本选中样式
查看>>
python3 字符串/列表/元组(str/list/tuple)相互转换方法及join()函数的使用
查看>>
[***]HZOJ 超级树
查看>>
Git 使用规范流程
查看>>
绝对音乐No.1
查看>>
Java 后端开发
查看>>
P4学习:统计功能
查看>>
获取INET4与INET6的信息
查看>>
POJ 2316
查看>>