php – 在laravel查询构建器中使用多个where子句

前端之家收集整理的这篇文章主要介绍了php – 在laravel查询构建器中使用多个where子句前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在转换以下SQL查询以使用laravels查询构建器时遇到了很多麻烦.
SELECT * FROM gifts 
JOIN giftcategory ON gifts.id = giftcategory.giftid
JOIN giftoccasions ON gifts.id = giftoccasions.giftid
JOIN giftrelationship ON gifts.id = giftrelationship.giftid

WHERE (gifts.gender = 'any' OR gifts.gender = 'male')
AND giftoccasions.occasionid = '2'
AND (giftcategory.categoryid = '0' OR giftcategory.categoryid = '1')
AND giftrelationship.relationshipid = '1'

查询工作正常,但在使用Laravels查询构建器时,我无法获得相同的结果.到目前为止,我有以下代码.它根本不能正常工作.我认为问题可能在于orWhere部分,因为它似乎返回的结果与其他where子句不匹配.

$giftQuery = DB::Table('gifts')
->Join('giftcategory','gifts.id','=','giftcategory.giftid')
->Join('giftoccasions','giftoccasions.giftid')
->where('gifts.gender',"male")
->orwhere('gifts.gender',"any")
->where('giftoccasions.occasionid',"2")
->where('giftoccasions.relationshipid',"1")
->Where('giftcategory.categoryid',"0")
->orWhere('giftcategory.categoryid',"1");
您想将 advanced where与参数分组一起使用:
$giftQuery = DB::table('gifts')
    ->join('giftcategory','giftcategory.giftid')
    ->join('giftoccasions','giftoccasions.giftid')
    ->where(function($query) {
        $query->where('gifts.gender',"male")
            ->orWhere('gifts.gender',"any");
    })
    ->where('giftoccasions.occasionid',"2")
    ->where('giftoccasions.relationshipid',"1")
    ->where('giftcategory.categoryid',"0")
    ->orWhere('giftcategory.categoryid',"1");
原文链接:https://www.f2er.com/laravel/134487.html

猜你在找的Laravel相关文章