将多个 where 子句与 laravel 查询构建器一起使用
Using multiple where clauses with laravel query builder
我在转换以下 SQL 查询以使用 Laravel 的查询构建器时遇到了很多问题。
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'
此查询工作正常,但在使用 Laravel 的查询生成器时无法获得相同的结果。到目前为止,我有以下代码。它根本无法正常工作。我认为问题可能出在 orWhere
部分,因为它返回的结果似乎与任何其他 where 子句都不匹配。
$giftQuery = DB::Table('gifts')
->Join('giftcategory', 'gifts.id', '=', 'giftcategory.giftid')
->Join('giftoccasions', 'gifts.id', '=', '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', 'gifts.id', '=', 'giftcategory.giftid')
->join('giftoccasions', 'gifts.id', '=', '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");
我在转换以下 SQL 查询以使用 Laravel 的查询构建器时遇到了很多问题。
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'
此查询工作正常,但在使用 Laravel 的查询生成器时无法获得相同的结果。到目前为止,我有以下代码。它根本无法正常工作。我认为问题可能出在 orWhere
部分,因为它返回的结果似乎与任何其他 where 子句都不匹配。
$giftQuery = DB::Table('gifts')
->Join('giftcategory', 'gifts.id', '=', 'giftcategory.giftid')
->Join('giftoccasions', 'gifts.id', '=', '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', 'gifts.id', '=', 'giftcategory.giftid')
->join('giftoccasions', 'gifts.id', '=', '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");