一.查询方式
件查询。在大多数情况下,推荐使用索引数组和对象方式作为查询条件,因为会更加安全
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 推荐使用数组形式更加高效。
二.表达式查询