我尝试使用 laravel 5.3 中的组进行查询。我发现
SQLSTATE[42000]:语法错误或访问冲突:1055 SELECT 列表的表达式 #17 不在 GROUP BY 子句中,并且包含非聚合列“testtravel.country.name”,该列在功能上不依赖于 GROUP BY 子句中的列;这与 sql_mode=only_full_group_by 不兼容(SQL:
select `travel_request`.*, `travel_request`.`id` as `travel_id`,
`department`.`name` as `dept_name`, `users`.`firstname` as `approver_name`,
`travel_purpose`.`purpose`, `country`.`name` as `country_name`,
`traveling_details`.`from_date`, `traveling_details`.`to_date`,
`travel_request_status`.`status`
from `travel_request`
inner join `department` ON `travel_request`.`department_id` = `department`.`id`
inner join `users` ON `travel_request`.`approver_id` = `users`.`id`
inner join `travel_purpose` ON `travel_request`.`travel_purpose_id` = `travel_purpose`.`id`
inner join `traveling_details` ON `travel_request`.`id` = `traveling_details`.`travel_request_id`
inner join `country` ON `country`.`id` = `traveling_details`.`country_id`
inner join `travel_request_status` ON `travel_request`.`status_id` = `travel_request_status`.`id`
where `travel_request`.`approver_id` = 187
and `travel_request`.`status_id` != 4
group by `travel_request`.`id`
limit 2 offset 0)
我复制了查询并在 sql 中运行。它在 mysql 中运行良好。我尝试过
$users = DB::table('travel_request')
->join('department', 'travel_request.department_id', '=', 'department.id')
->join('users', 'travel_request.approver_id', '=', 'users.id')
->join('travel_purpose', 'travel_request.travel_purpose_id', '=', 'travel_purpose.id')
->join('traveling_details', 'travel_request.id','=','traveling_details.travel_request_id' )
->join('country','country.id', '=', 'traveling_details.country_id')
->join('travel_request_status','travel_request.status_id', '=', 'travel_request_status.id')
->select('travel_request.*', 'travel_request.id as travel_id','department.name as dept_name','users.firstname as approver_name','travel_purpose.purpose','country.name as country_name','traveling_details.from_date','traveling_details.to_date','travel_request_status.status')->where('travel_request.approver_id', $user_id)->where('travel_request.status_id','!=','4')->GROUPBY ('travel_request.id')->paginate(2);
解决了
然而,要禁用此功能,只需转到 config/database.php 并更改 strict 标志
'mysql' => [
.
.
.
'strict' => false,
//'strict' => true,
.
.
],