Merge pull request #999 from doctrine/hotfix/DDC-3065-null-value-in-in-criteria-support
DDC-3065 null value in in criteria support
This commit is contained in:
commit
4185a9ce4b
@ -1541,7 +1541,13 @@ class BasicEntityPersister implements EntityPersister
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (is_array($value)) {
|
if (is_array($value)) {
|
||||||
return sprintf('%s IN (%s)' , $condition, $placeholder);
|
$in = sprintf('%s IN (%s)' , $condition, $placeholder);
|
||||||
|
|
||||||
|
if (false !== array_search(null, $value, true)) {
|
||||||
|
return sprintf('(%s OR %s IS NULL)' , $in, $condition);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $in;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($value === null) {
|
if ($value === null) {
|
||||||
|
@ -928,5 +928,89 @@ class EntityRepositoryTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
$repository = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser');
|
$repository = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser');
|
||||||
$repository->find(array('username = ?; DELETE FROM cms_users; SELECT 1 WHERE 1' => 'test', 'id' => 1));
|
$repository->find(array('username = ?; DELETE FROM cms_users; SELECT 1 WHERE 1' => 'test', 'id' => 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-3056
|
||||||
|
*/
|
||||||
|
public function testFindByNullValueInInCondition()
|
||||||
|
{
|
||||||
|
$user1 = new CmsUser();
|
||||||
|
$user2 = new CmsUser();
|
||||||
|
|
||||||
|
$user1->username = 'ocramius';
|
||||||
|
$user1->name = 'Marco';
|
||||||
|
$user2->status = null;
|
||||||
|
$user2->username = 'deeky666';
|
||||||
|
$user2->name = 'Steve';
|
||||||
|
$user2->status = 'dbal maintainer';
|
||||||
|
|
||||||
|
$this->_em->persist($user1);
|
||||||
|
$this->_em->persist($user2);
|
||||||
|
$this->_em->flush();
|
||||||
|
|
||||||
|
$users = $this->_em->getRepository('Doctrine\Tests\Models\CMS\CmsUser')->findBy(array('status' => array(null)));
|
||||||
|
|
||||||
|
$this->assertCount(1, $users);
|
||||||
|
$this->assertSame($user1, reset($users));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-3056
|
||||||
|
*/
|
||||||
|
public function testFindByNullValueInMultipleInCriteriaValues()
|
||||||
|
{
|
||||||
|
$user1 = new CmsUser();
|
||||||
|
$user2 = new CmsUser();
|
||||||
|
|
||||||
|
$user1->username = 'ocramius';
|
||||||
|
$user1->name = 'Marco';
|
||||||
|
$user2->status = null;
|
||||||
|
$user2->username = 'deeky666';
|
||||||
|
$user2->name = 'Steve';
|
||||||
|
$user2->status = 'dbal maintainer';
|
||||||
|
|
||||||
|
$this->_em->persist($user1);
|
||||||
|
$this->_em->persist($user2);
|
||||||
|
$this->_em->flush();
|
||||||
|
|
||||||
|
$users = $this
|
||||||
|
->_em
|
||||||
|
->getRepository('Doctrine\Tests\Models\CMS\CmsUser')
|
||||||
|
->findBy(array('status' => array('foo', null)));
|
||||||
|
|
||||||
|
$this->assertCount(1, $users);
|
||||||
|
$this->assertSame($user1, reset($users));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-3056
|
||||||
|
*/
|
||||||
|
public function testFindMultipleByNullValueInMultipleInCriteriaValues()
|
||||||
|
{
|
||||||
|
$user1 = new CmsUser();
|
||||||
|
$user2 = new CmsUser();
|
||||||
|
|
||||||
|
$user1->username = 'ocramius';
|
||||||
|
$user1->name = 'Marco';
|
||||||
|
$user2->status = null;
|
||||||
|
$user2->username = 'deeky666';
|
||||||
|
$user2->name = 'Steve';
|
||||||
|
$user2->status = 'dbal maintainer';
|
||||||
|
|
||||||
|
$this->_em->persist($user1);
|
||||||
|
$this->_em->persist($user2);
|
||||||
|
$this->_em->flush();
|
||||||
|
|
||||||
|
$users = $this
|
||||||
|
->_em
|
||||||
|
->getRepository('Doctrine\Tests\Models\CMS\CmsUser')
|
||||||
|
->findBy(array('status' => array('dbal maintainer', null)));
|
||||||
|
|
||||||
|
$this->assertCount(2, $users);
|
||||||
|
|
||||||
|
foreach ($users as $user) {
|
||||||
|
$this->assertTrue(in_array($user, array($user1, $user2)));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,9 +11,19 @@ use Doctrine\Common\Collections\Expr\Comparison;
|
|||||||
|
|
||||||
class BasicEntityPersisterTypeValueSqlTest extends \Doctrine\Tests\OrmTestCase
|
class BasicEntityPersisterTypeValueSqlTest extends \Doctrine\Tests\OrmTestCase
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @var BasicEntityPersister
|
||||||
|
*/
|
||||||
protected $_persister;
|
protected $_persister;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \Doctrine\ORM\EntityManager
|
||||||
|
*/
|
||||||
protected $_em;
|
protected $_em;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
protected function setUp()
|
protected function setUp()
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
@ -108,4 +118,25 @@ class BasicEntityPersisterTypeValueSqlTest extends \Doctrine\Tests\OrmTestCase
|
|||||||
$statement = $this->_persister->getSelectConditionStatementSQL('test', null, array(), Comparison::NEQ);
|
$statement = $this->_persister->getSelectConditionStatementSQL('test', null, array(), Comparison::NEQ);
|
||||||
$this->assertEquals('test IS NOT NULL', $statement);
|
$this->assertEquals('test IS NOT NULL', $statement);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-3056
|
||||||
|
*/
|
||||||
|
public function testSelectConditionStatementWithMultipleValuesContainingNull()
|
||||||
|
{
|
||||||
|
$this->assertEquals(
|
||||||
|
'(t0.id IN (?) OR t0.id IS NULL)',
|
||||||
|
$this->_persister->getSelectConditionStatementSQL('id', array(null))
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
'(t0.id IN (?) OR t0.id IS NULL)',
|
||||||
|
$this->_persister->getSelectConditionStatementSQL('id', array(null, 123))
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
'(t0.id IN (?) OR t0.id IS NULL)',
|
||||||
|
$this->_persister->getSelectConditionStatementSQL('id', array(123, null))
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user