У меня есть таблица под названием tenantdetails
, которая содержит
Tenant_Id | First_Name | Last_Name | ........
и я хочу получить First_Name
и Last Name
как один столбец через функцию конкатенации MySQL. Поэтому я пишу в controller
следующим образом
$tenants = Tenant::orderBy('First_Name')->lists('CONCAT(`First_Name`," ",`Last_Name`)','Tenant_Id');
Но возникает следующая ошибка:
SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '`," ",`First_Name`)`, `Id` from `tenantdetails` order by `F' at line 1 (SQL: select `CONCAT(`First_Name`," ",`Last_Name`)`, `Id` from `tenantdetails` order by `First_Name` asc).
Как мы можем избежать обратных шагов при вызове функции MySQL в Laravel Rloquent. Меня интересует только Eloquent (не в беглом запросе). Спасибо заранее.
Обновление
Спасибо @Andreyco за помощь мне. Мы можем добиться этого более элегантным способом с использованием моделей Laravel, как показано ниже:
В нашем model
:
public function getTenantFullNameAttribute()
{
return $this->attributes['First_Name'] .' '. $this->attributes['Last_Name'];
}
и в нашем controller
:
$tenants = Tenant::orderBy('First_Name')->get();
$tenants = $tenants->lists('TenantFullName', 'Tenant_Id');