From 75ec9c3939601c2a6c6885a9333109214a2eb204 Mon Sep 17 00:00:00 2001 From: Propaganistas Date: Mon, 12 Sep 2022 17:00:55 +0200 Subject: [PATCH] Fix QueryBuilder whereNot with array conditions (#44083) * bugfix * consequences * boyscout rule * styleci * narrow surface area Co-authored-by: Taylor Otwell --- src/Illuminate/Database/Query/Builder.php | 8 +++++++- tests/Database/DatabaseQueryBuilderTest.php | 18 ++++++++++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/src/Illuminate/Database/Query/Builder.php b/src/Illuminate/Database/Query/Builder.php index 799463d6099b..59f45d27acd9 100755 --- a/src/Illuminate/Database/Query/Builder.php +++ b/src/Illuminate/Database/Query/Builder.php @@ -800,7 +800,7 @@ protected function addArrayOfWheres($column, $boolean, $method = 'where') if (is_numeric($key) && is_array($value)) { $query->{$method}(...array_values($value)); } else { - $query->$method($key, '=', $value, $boolean); + $query->{$method}($key, '=', $value, $boolean); } } }, $boolean); @@ -894,6 +894,12 @@ public function orWhere($column, $operator = null, $value = null) */ public function whereNot($column, $operator = null, $value = null, $boolean = 'and') { + if (is_array($column)) { + return $this->whereNested(function ($query) use ($column, $operator, $value, $boolean) { + $query->where($column, $operator, $value, $boolean); + }, $boolean.' not'); + } + return $this->where($column, $operator, $value, $boolean.' not'); } diff --git a/tests/Database/DatabaseQueryBuilderTest.php b/tests/Database/DatabaseQueryBuilderTest.php index d7c6ed2dc617..05a88f51baa0 100755 --- a/tests/Database/DatabaseQueryBuilderTest.php +++ b/tests/Database/DatabaseQueryBuilderTest.php @@ -1748,6 +1748,24 @@ public function testWhereNot() $this->assertEquals([0 => 'bar', 1 => 'foo'], $builder->getBindings()); } + public function testWhereNotWithArrayConditions() + { + $builder = $this->getBuilder(); + $builder->select('*')->from('users')->whereNot([['foo', 1], ['bar', 2]]); + $this->assertSame('select * from "users" where not (("foo" = ? and "bar" = ?))', $builder->toSql()); + $this->assertEquals([0 => 1, 1 => 2], $builder->getBindings()); + + $builder = $this->getBuilder(); + $builder->select('*')->from('users')->whereNot(['foo' => 1, 'bar' => 2]); + $this->assertSame('select * from "users" where not (("foo" = ? and "bar" = ?))', $builder->toSql()); + $this->assertEquals([0 => 1, 1 => 2], $builder->getBindings()); + + $builder = $this->getBuilder(); + $builder->select('*')->from('users')->whereNot([['foo', 1], ['bar', '<', 2]]); + $this->assertSame('select * from "users" where not (("foo" = ? and "bar" < ?))', $builder->toSql()); + $this->assertEquals([0 => 1, 1 => 2], $builder->getBindings()); + } + public function testFullSubSelects() { $builder = $this->getBuilder();