首页 技术 正文
技术 2022年11月7日
0 收藏 576 点赞 845 浏览 1556 个字

ThinkPHP中对查询语句,包含了基本的查询方式、表达方式、快速查询、区间查询、组合查询、SQL查询、动态查询和子查询。

一、查询方式

ThinkPHP提供了三种基本的查询方式:字符串条件查询、索引数组条件查询和对象条件查询。在大多情况下,推荐使用索引数组和对象方式作为查询条件,因为会更安全。

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

$user = M(‘user’);

var_dump($user->where(‘id=1 AND user=”姓名”‘)->select());

//最终生成的SQL语句

select * from ‘user’ where (id=1 AND user=”姓名”)

注意:where查询方法里面只要包含条件即可,多个条件加上AND等连接符即可。

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

$user = M('user');
$condition['id'] = 1;
$condition['user'] = 'name';
var_dump($user->where($condition)->select());
//最终生成的SQL语句
select * from 'user' where ('id'=1)AND('user' = 'name')

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

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

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

3.使用对象方式来查询

$user = M('user');
$condition = new \stdClass();
$condition->id = 1;
$condition->user = 'name';
var_dump($user->where($condition)->select());
//最终生成的SQL语句
select * from user where ('id' = 1) AND ('user' = 'name')

注意:stdClass类是php内置的类,可以理解为一个空类,在这里可以理解为把条件的字段作为成员保存到stdClass类里。而这里的’\’是将命名空间设置为根目录,否则会导致当前目录找不到此类。使用对象和数组查询,效果是一样的,可以互换。在大多数情况下,ThinPHP推荐使用数组形式更高效。

二、表达式查询

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

注意:表达式不区分大小写。

//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(‘like’,array(‘%小%’,’%大%’),’AND’);

//生成的SQL

select * from ‘user’ where ((‘name’ like ‘%小%’ AND ‘name’ like ‘%大%’));

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,489
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,904
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,737
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,490
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,128
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,291