1
0
mirror of synced 2025-01-25 01:31:40 +03:00

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:
Guilherme Blanco 2014-04-20 23:30:14 -04:00
commit 4185a9ce4b
3 changed files with 122 additions and 1 deletions

View File

@ -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) {

View File

@ -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)));
}
}
} }

View File

@ -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))
);
}
} }