这是我的代码:
protected function room_count($room_count)
{
$query = $this->builder
->whereJsonContains('rent_requests.rooms_count', $room_count);
return $query;
}
有我的过滤功能。$room_count
是数组,例如可以是[2,4]
.
rent_requests.rooms_count
是MySQL中的JSON数组,可以是例如[2,3]
。
我需要过滤这个,才能显示这个广告,但是 whereJSONContains 期望会有2 and 4
, not 2 or 4
。
有什么技巧可以让这个功能正常工作吗?像 json 这样的东西包含 whereIn ?)
抱歉我的英语不好,我真的很困惑,请帮助我:)
MySQL 和 PostgreSQL 支持具有多个值的 whereJsonContains:
因此,如果您使用任一数据库,则可以传递 $room_count 作为第二个参数
// Room Count Filter
protected function room_count($room_count)
{
return $this->builder
->where(function($query) use($room_count){
$query->whereJsonContains('rent_requests.rooms_count', $room_count[0]);
for($i = 1; $i < count($room_count); $i++) {
$query->orWhereJsonContains('rent_requests.rooms_count', $room_count[$i]);
}
return $query;
});
}
Laravel 文档:https://laravel.com/docs/8.x/queries#json-where-clauses
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)