1. 使用字符串作为条件查询
// 字符串作为条件查询
$user = M( 'User' );
var_dump($user->where(
var_dump($user->where( 'id=1 AND user=" 蜡笔小新 "' )->select());
// 最终生成的 SQL
语句
SELECT * FROM `think_user` WHERE ( id=1 AND user=" 蜡笔小新 " )
2. 使用索引数组作为查询条件
// 索引数组作为条件查询
$user = M( 'User' );
$condition[ 'id' ] = 1;
$condition[ 'user' ] = ' 蜡笔小新 ' ;
$condition[ '_logic' ] = 'OR' ; // 将默认 AND
改成 OR
var_dump($user->where($condition)->select());
// 最终生成的 SQL
语句
SELECT * FROM `think_user` WHERE ( `id` = 1 ) AND ( `user` = ' 蜡笔小
新 ' )
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 推荐使用数组形式更加高效。