请教,Model::find($id)不是范围键=$id 的那一行数据吗?今天测试发现返回整个数据表全部数据。 使用的 Laravel 版本:5.5.45
Model 文件:
namespace App; use DB;
class User extends Model { public $table = 'users'; public $primaryKey = 'id';
static public function getU($user_id)
{
DB::connection()->enableQueryLog();
$user = self::find($user_id)->get();
$u = [];
$u['getQueryLog'] = DB::getQueryLog();
$u['SQL'] = self::find($user_id)->toSql();
return $u;
}
}
在 Controller 文件中调用 $u = User::getU(820); var_dump($u);
打印出来的内容:
array(2) {
["getQueryLog"]=>
array(2) {
[0]=>
array(3) {
["query"]=>
string(52) "select * from users
where users
.id
= ? limit 1"
["bindings"]=>
array(1) {
[0]=>
int(820)
}
["time"]=>
float(2.02)
}
[1]=>
array(3) {
["query"]=>
string(21) "select * from users
"
["bindings"]=>
array(0) {
}
["time"]=>
float(3.74)
}
}
["SQL"]=>
string(21) "select * from users
"
}
可以看到 DB::getQueryLog() 返回了两个 sql 执行记录,为什么会出现两条呢?感觉是被第二条 sql 覆盖了第一条?
1
niucility 2019-03-21 21:34:48 +08:00 via Android 1
为啥 find 后还要 get()
|