私は観光機関のウェブサイトをプログラミングしています。私は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つのホテルを検索すると、私は5つ星ホテルしか得られません!
ホテルを4,3星で検索すると、4つ星ホテルのみが手に入ります!私はデータベースから何も得られません!
1つまたは3つ星または5つ星のホテルを同時に取得できるようにするにはどうすればよいですか?
感謝の男。それは完璧に働いた! –