ThinkPHP3.2.3使用对象方式来查询
这里以stdClass内置对象为例:
$User = M("User"); // 实例化User对象 // 定义查询条件 $condition = new stdClass(); $condition->name = 'thinkphp'; $condition->status= 1; $User->where($condition)->select();
最后生成的SQL语句和上面一样
SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1
使用对象方式查询和使用数组查询的效果是相同的,并且是可以互换的,大多数情况下,我们建议采用数组方式更加高效。
在使用数组和对象方式查询的时候,如果传入了不存在的查询字段是会被自动过滤的,例如:
$User = M("User"); // 实例化User对象 $condition['name'] = 'thinkphp'; $condition['status'] = 1; $condition['test'] = 'test'; // 把查询条件传入查询方法 $User->where($condition)->select();
因为数据库的test字段是不存在的,所以系统会自动检测并过滤掉$condition['test'] = 'test'
这一查询条件。
如果是3.2.2版本以上,当开启调试模式的话,则会抛出异常,显示:
错误的查询条件
。