您的位置:首页 > 编程语言 > PHP开发

ThinkPHP(3)SQL查询语句

2016-06-29 13:28 323 查看
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 '%大%'));
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: