标签:php methods laravel eloquent laravel-5-2
这是Laravel 5.2.我的用户模型中有一个如下定义的方法:
public function name()
{
return "$this->name_first $this->name_last";
}
我试图找出如何使用它作为查询的一部分,但似乎不可能有一个明显的原因:数据库不知道任何关于方法的东西,这是完全合理的.然而,我想要实现的概念在某些情境中是有意义的,所以我试图看看是否有办法在Eloquent中自然地完成它.
这不起作用,但它代表了我正在努力实现的目标:
public function index(Request $request)
{
$query = new User();
if(Request::has('name')) {
$query = $query->where('name', 'LIKE', '%' . Request::input('name') . '%');
}
return $query->get();
}
简而言之,数据库只知道name_first和name_last,但我希望能够在不存储名称的情况下搜索(和排序)名称.也许存储连接的名称没什么大不了的,我应该这样做,但我也在努力学习.
解决方法:
我同意Bogdan的观点,在第一个或者最后一个名字中都有空格的问题使得对各个列的查询很困难,所以这可能是要走的路.通过将其定义为自定义范围,可以增加代码重用:
https://laravel.com/docs/5.2/eloquent#local-scopes
// class User
public function scopeOfFullNameLike($query, $fullName)
{
return $query->whereRaw('CONCAT(name_first, " ", name_last) LIKE "%?%"', [$fullName]);
}
// ...
User::ofFullNameLike('john doe')->get();
标签:php,methods,laravel,eloquent,laravel-5-2 来源: https://codeday.me/bug/20190516/1115897.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。