在 eloquent 查询中使用 eloquent 遍历数组以获取数据
looping through array to get data using eloquent inside eloquent query
我正在编写一个旅游代理网站。我在数据库中 hotels
有一个名为 stars
的列,它是一个整数,其值在 1 到 5 之间。
我有一个表格,用户可以根据 stars
搜索酒店。该字段是 checkbox
,因此他可以同时搜索 five stars
和 four stars
酒店。
我阅读了 stars array
并使用以下代码将访问者重定向到搜索页面:
$stars_param = "";
$i = 1;
foreach($stars as $star){
if($i == 1){
$stars_param .= $star;
}else{
$stars_param .= "&".$star;
}
$i++;
}
$parameters = "filter=true&&stars=".$stars_param."&&price=".$price."&&area=".$area;
return \Redirect::to('/hotels-search/?'.$parameters);
所以 url 将是这样的:
hotels-search?filter=true&&stars=5&1&&price=300&&area=taksim
并且在 hotels-search
页面中我阅读了 $_GET
,并分解了 stars 变量并编写了此查询以获取数据:
$stars = $_GET['stars'];
$stars_array = explode('&', $stars);
$price = $_GET['price'];
$area = $_GET['area'];
$this['hotels'] = \Lilessam\Hotels\Models\Hotel::orderBy('id', 'desc')->where(function($query) use($stars_array){
$i = 1;
foreach($stars_array as $star){
if($i == 1){
$query->where('stars', $star);
}else{
$query->orWhere('stars', $star);
}
$i++;
}
})->where('price', '<=', $price)->whereHas('area', function($query) use($area){
$query->where('name', 'LIKE', $area);
})->paginate(5);
但是如果我用这个搜索 5 星和 1 星的酒店,我只会得到五星级的酒店!
如果我搜索 4 星和 3 星酒店,我只会得到四星级酒店!其他时候我从数据库中什么也得不到!
如何查询才能同时获得 1 星、3 星或 5 星的酒店?!
你为什么不用这个
$this['hotels'] = \Lilessam\Hotels\Models\Hotel::orderBy('id', 'desc')
->whereIn('start',$stars_array)
->where('price', '<=', $price)
->whereHas('area', function($query) use($area){
$query->where('name', 'LIKE', $area);
})->paginate(5);
get 变量由单个 &
分隔,而不是 &&
。每个名称值对都具有以下形式:- name=value.
试试这个。
$stars_param = implode(",",$stars);
$parameters = "filter=true&stars=".$stars_param."&price=".$price."&area=".$area;
return \Redirect::to('/hotels-search/?'.$parameters);
那么您的 URL 将是:
hotels-search?filter=true&stars=5,1&price=300&area=taksim
并在酒店搜索页面
$stars = $_GET['stars'];
$stars_array = explode(',', $stars);
$price = $_GET['price'];
$area = $_GET['area'];
希望这对您有所帮助...
我正在编写一个旅游代理网站。我在数据库中 hotels
有一个名为 stars
的列,它是一个整数,其值在 1 到 5 之间。
我有一个表格,用户可以根据 stars
搜索酒店。该字段是 checkbox
,因此他可以同时搜索 five stars
和 four stars
酒店。
我阅读了 stars array
并使用以下代码将访问者重定向到搜索页面:
$stars_param = "";
$i = 1;
foreach($stars as $star){
if($i == 1){
$stars_param .= $star;
}else{
$stars_param .= "&".$star;
}
$i++;
}
$parameters = "filter=true&&stars=".$stars_param."&&price=".$price."&&area=".$area;
return \Redirect::to('/hotels-search/?'.$parameters);
所以 url 将是这样的:
hotels-search?filter=true&&stars=5&1&&price=300&&area=taksim
并且在 hotels-search
页面中我阅读了 $_GET
,并分解了 stars 变量并编写了此查询以获取数据:
$stars = $_GET['stars'];
$stars_array = explode('&', $stars);
$price = $_GET['price'];
$area = $_GET['area'];
$this['hotels'] = \Lilessam\Hotels\Models\Hotel::orderBy('id', 'desc')->where(function($query) use($stars_array){
$i = 1;
foreach($stars_array as $star){
if($i == 1){
$query->where('stars', $star);
}else{
$query->orWhere('stars', $star);
}
$i++;
}
})->where('price', '<=', $price)->whereHas('area', function($query) use($area){
$query->where('name', 'LIKE', $area);
})->paginate(5);
但是如果我用这个搜索 5 星和 1 星的酒店,我只会得到五星级的酒店!
如果我搜索 4 星和 3 星酒店,我只会得到四星级酒店!其他时候我从数据库中什么也得不到!
如何查询才能同时获得 1 星、3 星或 5 星的酒店?!
你为什么不用这个
$this['hotels'] = \Lilessam\Hotels\Models\Hotel::orderBy('id', 'desc')
->whereIn('start',$stars_array)
->where('price', '<=', $price)
->whereHas('area', function($query) use($area){
$query->where('name', 'LIKE', $area);
})->paginate(5);
get 变量由单个 &
分隔,而不是 &&
。每个名称值对都具有以下形式:- name=value.
试试这个。
$stars_param = implode(",",$stars);
$parameters = "filter=true&stars=".$stars_param."&price=".$price."&area=".$area;
return \Redirect::to('/hotels-search/?'.$parameters);
那么您的 URL 将是:
hotels-search?filter=true&stars=5,1&price=300&area=taksim
并在酒店搜索页面
$stars = $_GET['stars'];
$stars_array = explode(',', $stars);
$price = $_GET['price'];
$area = $_GET['area'];
希望这对您有所帮助...