簡體   English   中英

使用雄辯的內部雄辯查詢遍歷數組以獲取數據

[英]looping through array to get data using eloquent inside eloquent query

我正在為一個旅行社網站編程。 我在數據庫中有一些hotels ,其中有一個名為stars的列,它是一個整數,其值在1到5之間。

我有一個表格,用戶可以根據stars搜索酒店。 該字段為checkbox因此他可以一起搜索five starsfour 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); 

因此,網址將如下所示:

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星級的酒店,那么我只會得到5星級的酒店!

如果我搜索4星級和3星級的酒店,我只會得到4星級的酒店! 有時候我根本沒有從數據庫中獲得任何東西!

我該如何查詢,以便同時獲得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);

那么您的網址將是:

hotels-search?filter=true&stars=5,1&price=300&area=taksim

並在酒店搜索頁面

$stars = $_GET['stars'];
$stars_array = explode(',', $stars);
$price = $_GET['price'];
$area = $_GET['area'];

希望這個能對您有所幫助...

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM