Failed Conditions
Pull Request — 2.6 (#7180)
by Ben
11:16
created

testJoinOnClause_NotYetSupported_ThrowsException()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 7
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 4
nc 1
nop 0
dl 0
loc 7
rs 9.4285
c 0
b 0
f 0
1
<?php
2
3
namespace Doctrine\Tests\ORM\Query;
4
5
use Doctrine\DBAL\LockMode;
6
use Doctrine\DBAL\Platforms\MySqlPlatform;
7
use Doctrine\DBAL\Platforms\OraclePlatform;
8
use Doctrine\DBAL\Platforms\PostgreSqlPlatform;
9
use Doctrine\DBAL\Platforms\SqlitePlatform;
10
use Doctrine\DBAL\Platforms\SQLServerPlatform;
11
use Doctrine\DBAL\Types\Type as DBALType;
12
use Doctrine\ORM\Query as ORMQuery;
13
use Doctrine\ORM\Query\AST\Functions\FunctionNode;
14
use Doctrine\ORM\Query\Lexer;
15
use Doctrine\ORM\Query\Parser;
16
use Doctrine\ORM\Query\QueryException;
17
use Doctrine\ORM\Query\SqlWalker;
18
use Doctrine\Tests\DbalTypes\NegativeToPositiveType;
19
use Doctrine\Tests\Models\CMS\CmsGroup;
20
use Doctrine\Tests\Models\CMS\CmsPhonenumber;
21
use Doctrine\Tests\Models\Company\CompanyEmployee;
22
use Doctrine\Tests\Models\Company\CompanyPerson;
23
use Doctrine\Tests\OrmTestCase;
24
25
class SelectSqlGenerationTest extends OrmTestCase
26
{
27
    private $_em;
28
29
    protected function setUp()
30
    {
31
        $this->_em = $this->_getTestEntityManager();
32
    }
33
34
    /**
35
     * Assert a valid SQL generation.
36
     *
37
     * @param string $dqlToBeTested
38
     * @param string $sqlToBeConfirmed
39
     * @param array $queryHints
40
     * @param array $queryParams
41
     */
42
    public function assertSqlGeneration($dqlToBeTested, $sqlToBeConfirmed, array $queryHints = [], array $queryParams = [])
43
    {
44
        try {
45
            $query = $this->_em->createQuery($dqlToBeTested);
46
47
            foreach ($queryParams AS $name => $value) {
48
                $query->setParameter($name, $value);
49
            }
50
51
            $query->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true)
52
                  ->useQueryCache(false);
53
54
            foreach ($queryHints AS $name => $value) {
55
                $query->setHint($name, $value);
56
            }
57
58
            $sqlGenerated = $query->getSQL();
59
60
            parent::assertEquals(
61
                $sqlToBeConfirmed,
62
                $sqlGenerated,
63
                sprintf('"%s" is not equal of "%s"', $sqlGenerated, $sqlToBeConfirmed)
64
            );
65
66
            $query->free();
67
        } catch (\Exception $e) {
68
            $this->fail($e->getMessage() ."\n".$e->getTraceAsString());
69
        }
70
    }
71
72
    /**
73
     * Asser an invalid SQL generation.
74
     *
75
     * @param string $dqlToBeTested
76
     * @param string $expectedException
77
     * @param array $queryHints
78
     * @param array $queryParams
79
     */
80
    public function assertInvalidSqlGeneration($dqlToBeTested, $expectedException, array $queryHints = [], array $queryParams = [])
81
    {
82
        $this->expectException($expectedException);
83
84
        $query = $this->_em->createQuery($dqlToBeTested);
85
86
        foreach ($queryParams AS $name => $value) {
87
            $query->setParameter($name, $value);
88
        }
89
90
        $query->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true)
91
              ->useQueryCache(false);
92
93
        foreach ($queryHints AS $name => $value) {
94
            $query->setHint($name, $value);
95
        }
96
97
        $sql = $query->getSql();
98
        $query->free();
99
100
        // If we reached here, test failed
101
        $this->fail($sql);
102
    }
103
104
    /**
105
     * @group DDC-3697
106
     */
107
    public function testJoinWithRangeVariablePutsConditionIntoSqlWhereClause()
108
    {
109
        $this->assertSqlGeneration(
110
            'SELECT c.id FROM Doctrine\Tests\Models\Company\CompanyPerson c JOIN Doctrine\Tests\Models\Company\CompanyPerson r WHERE c.spouse = r AND r.id = 42',
111
            'SELECT c0_.id AS id_0 FROM company_persons c0_ INNER JOIN company_persons c1_ WHERE c0_.spouse_id = c1_.id AND c1_.id = 42',
112
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => true]
113
        );
114
    }
115
116
    /**
117
     * @group DDC-3697
118
     */
119
    public function testJoinWithRangeVariableAndInheritancePutsConditionIntoSqlWhereClause()
120
    {
121
        /*
122
         * Basically like the previous test, but this time load data for the inherited objects as well.
123
         * The important thing is that the ON clauses in LEFT JOINs only contain the conditions necessary to join the appropriate inheritance table
124
         * whereas the filtering condition must remain in the SQL WHERE clause.
125
         */
126
        $this->assertSqlGeneration(
127
            'SELECT c.id FROM Doctrine\Tests\Models\Company\CompanyPerson c JOIN Doctrine\Tests\Models\Company\CompanyPerson r WHERE c.spouse = r AND r.id = 42',
128
            'SELECT c0_.id AS id_0 FROM company_persons c0_ LEFT JOIN company_managers c1_ ON c0_.id = c1_.id LEFT JOIN company_employees c2_ ON c0_.id = c2_.id INNER JOIN company_persons c3_ LEFT JOIN company_managers c4_ ON c3_.id = c4_.id LEFT JOIN company_employees c5_ ON c3_.id = c5_.id WHERE c0_.spouse_id = c3_.id AND c3_.id = 42',
129
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
130
        );
131
    }
132
133
    public function testSupportsSelectForAllFields()
134
    {
135
        $this->assertSqlGeneration(
136
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u',
137
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_'
138
        );
139
    }
140
141
    public function testSupportsSelectForOneField()
142
    {
143
        $this->assertSqlGeneration(
144
            'SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u',
145
            'SELECT c0_.id AS id_0 FROM cms_users c0_'
146
        );
147
    }
148
149
    public function testSupportsSelectForOneNestedField()
150
    {
151
        $this->assertSqlGeneration(
152
            'SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsArticle a JOIN a.user u',
153
            'SELECT c0_.id AS id_0 FROM cms_articles c1_ INNER JOIN cms_users c0_ ON c1_.user_id = c0_.id'
154
        );
155
    }
156
157
    public function testSupportsSelectForAllNestedField()
158
    {
159
        $this->assertSqlGeneration(
160
            'SELECT a FROM Doctrine\Tests\Models\CMS\CmsArticle a JOIN a.user u ORDER BY u.name ASC',
161
            'SELECT c0_.id AS id_0, c0_.topic AS topic_1, c0_.text AS text_2, c0_.version AS version_3 FROM cms_articles c0_ INNER JOIN cms_users c1_ ON c0_.user_id = c1_.id ORDER BY c1_.name ASC'
162
        );
163
    }
164
165
    public function testNotExistsExpression()
166
    {
167
        $this->assertSqlGeneration(
168
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE NOT EXISTS (SELECT p.phonenumber FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p WHERE p.phonenumber = 1234)',
169
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE NOT EXISTS (SELECT c1_.phonenumber FROM cms_phonenumbers c1_ WHERE c1_.phonenumber = 1234)'
170
        );
171
    }
172
173
    public function testSupportsSelectForMultipleColumnsOfASingleComponent()
174
    {
175
        $this->assertSqlGeneration(
176
            'SELECT u.username, u.name FROM Doctrine\Tests\Models\CMS\CmsUser u',
177
            'SELECT c0_.username AS username_0, c0_.name AS name_1 FROM cms_users c0_'
178
        );
179
    }
180
181
    public function testSupportsSelectUsingMultipleFromComponents()
182
    {
183
        $this->assertSqlGeneration(
184
            'SELECT u, p FROM Doctrine\Tests\Models\CMS\CmsUser u, Doctrine\Tests\Models\CMS\CmsPhonenumber p WHERE u = p.user',
185
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c1_.phonenumber AS phonenumber_4 FROM cms_users c0_, cms_phonenumbers c1_ WHERE c0_.id = c1_.user_id'
186
        );
187
    }
188
189
    public function testSupportsJoinOnMultipleComponents()
190
    {
191
        $this->assertSqlGeneration(
192
            'SELECT u, p FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN Doctrine\Tests\Models\CMS\CmsPhonenumber p WITH u = p.user',
193
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c1_.phonenumber AS phonenumber_4 FROM cms_users c0_ INNER JOIN cms_phonenumbers c1_ ON (c0_.id = c1_.user_id)'
194
        );
195
    }
196
197
    public function testSupportsJoinOnMultipleComponentsWithJoinedInheritanceType()
198
    {
199
        $this->assertSqlGeneration(
200
            'SELECT e FROM Doctrine\Tests\Models\Company\CompanyEmployee e JOIN Doctrine\Tests\Models\Company\CompanyManager m WITH e.id = m.id',
201
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c0_.discr AS discr_5 FROM company_employees c1_ INNER JOIN company_persons c0_ ON c1_.id = c0_.id INNER JOIN (company_managers c2_ INNER JOIN company_employees c4_ ON c2_.id = c4_.id INNER JOIN company_persons c3_ ON c2_.id = c3_.id) ON (c0_.id = c3_.id)'
202
        );
203
204
        $this->assertSqlGeneration(
205
            'SELECT e FROM Doctrine\Tests\Models\Company\CompanyEmployee e LEFT JOIN Doctrine\Tests\Models\Company\CompanyManager m WITH e.id = m.id',
206
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c0_.discr AS discr_5 FROM company_employees c1_ INNER JOIN company_persons c0_ ON c1_.id = c0_.id LEFT JOIN (company_managers c2_ INNER JOIN company_employees c4_ ON c2_.id = c4_.id INNER JOIN company_persons c3_ ON c2_.id = c3_.id) ON (c0_.id = c3_.id)'
207
        );
208
209
        $this->assertSqlGeneration(
210
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyContract c JOIN c.salesPerson s LEFT JOIN Doctrine\Tests\Models\Company\CompanyEvent e WITH s.id = e.id',
211
            'SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6 FROM company_contracts c0_ INNER JOIN company_employees c1_ ON c0_.salesPerson_id = c1_.id LEFT JOIN company_persons c2_ ON c1_.id = c2_.id LEFT JOIN company_events c3_ ON (c2_.id = c3_.id) WHERE c0_.discr IN (\'fix\', \'flexible\', \'flexultra\')'
212
        );
213
    }
214
215
    public function testSupportsSelectWithCollectionAssociationJoin()
216
    {
217
        $this->assertSqlGeneration(
218
            'SELECT u, p FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.phonenumbers p',
219
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c1_.phonenumber AS phonenumber_4 FROM cms_users c0_ INNER JOIN cms_phonenumbers c1_ ON c0_.id = c1_.user_id'
220
        );
221
    }
222
223
    public function testSupportsSelectWithSingleValuedAssociationJoin()
224
    {
225
        $this->assertSqlGeneration(
226
            'SELECT u, a FROM Doctrine\Tests\Models\Forum\ForumUser u JOIN u.avatar a',
227
            'SELECT f0_.id AS id_0, f0_.username AS username_1, f1_.id AS id_2 FROM forum_users f0_ INNER JOIN forum_avatars f1_ ON f0_.avatar_id = f1_.id'
228
        );
229
    }
230
231
    public function testSelectCorrelatedSubqueryComplexMathematicalExpression()
232
    {
233
        $this->assertSqlGeneration(
234
            'SELECT (SELECT (count(p.phonenumber)+5)*10 FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p JOIN p.user ui WHERE ui.id = u.id) AS c FROM Doctrine\Tests\Models\CMS\CmsUser u',
235
            'SELECT (SELECT (count(c0_.phonenumber) + 5) * 10 AS sclr_1 FROM cms_phonenumbers c0_ INNER JOIN cms_users c1_ ON c0_.user_id = c1_.id WHERE c1_.id = c2_.id) AS sclr_0 FROM cms_users c2_'
236
        );
237
    }
238
239
    public function testSelectComplexMathematicalExpression()
240
    {
241
        $this->assertSqlGeneration(
242
            'SELECT (count(p.phonenumber)+5)*10 FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p JOIN p.user ui WHERE ui.id = ?1',
243
            'SELECT (count(c0_.phonenumber) + 5) * 10 AS sclr_0 FROM cms_phonenumbers c0_ INNER JOIN cms_users c1_ ON c0_.user_id = c1_.id WHERE c1_.id = ?'
244
        );
245
    }
246
247
    /* NOT (YET?) SUPPORTED.
248
       Can be supported if SimpleSelectExpression supports SingleValuedPathExpression instead of StateFieldPathExpression.
249
250
    public function testSingleAssociationPathExpressionInSubselect()
251
    {
252
        $this->assertSqlGeneration(
253
            'SELECT (SELECT p.user FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p WHERE p.user = u) user_id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = ?1',
254
            'SELECT (SELECT c0_.user_id FROM cms_phonenumbers c0_ WHERE c0_.user_id = c1_.id) AS sclr_0 FROM cms_users c1_ WHERE c1_.id = ?'
255
        );
256
    }*/
257
258
    /**
259
     * @group DDC-1077
260
     */
261
    public function testConstantValueInSelect()
262
    {
263
        $this->assertSqlGeneration(
264
            "SELECT u.name, 'foo' AS bar FROM Doctrine\Tests\Models\CMS\CmsUser u",
265
            "SELECT c0_.name AS name_0, 'foo' AS sclr_1 FROM cms_users c0_"
266
        );
267
    }
268
269
    public function testSupportsOrderByWithAscAsDefault()
270
    {
271
        $this->assertSqlGeneration(
272
            'SELECT u FROM Doctrine\Tests\Models\Forum\ForumUser u ORDER BY u.id',
273
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ ORDER BY f0_.id ASC'
274
        );
275
    }
276
277
    public function testSupportsOrderByAsc()
278
    {
279
        $this->assertSqlGeneration(
280
            'SELECT u FROM Doctrine\Tests\Models\Forum\ForumUser u ORDER BY u.id asc',
281
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ ORDER BY f0_.id ASC'
282
        );
283
    }
284
    public function testSupportsOrderByDesc()
285
    {
286
        $this->assertSqlGeneration(
287
            'SELECT u FROM Doctrine\Tests\Models\Forum\ForumUser u ORDER BY u.id desc',
288
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ ORDER BY f0_.id DESC'
289
        );
290
    }
291
292
    public function testSupportsSelectDistinct()
293
    {
294
        $this->assertSqlGeneration(
295
            'SELECT DISTINCT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u',
296
            'SELECT DISTINCT c0_.name AS name_0 FROM cms_users c0_'
297
        );
298
    }
299
300
    public function testSupportsAggregateFunctionInSelectedFields()
301
    {
302
        $this->assertSqlGeneration(
303
            'SELECT COUNT(u.id) FROM Doctrine\Tests\Models\CMS\CmsUser u GROUP BY u.id',
304
            'SELECT COUNT(c0_.id) AS sclr_0 FROM cms_users c0_ GROUP BY c0_.id'
305
        );
306
    }
307
308
    public function testSupportsAggregateFunctionWithSimpleArithmetic()
309
    {
310
        $this->assertSqlGeneration(
311
            'SELECT MAX(u.id + 4) * 2 FROM Doctrine\Tests\Models\CMS\CmsUser u',
312
            'SELECT MAX(c0_.id + 4) * 2 AS sclr_0 FROM cms_users c0_'
313
        );
314
    }
315
316
    /**
317
     * @group DDC-3276
318
     */
319
    public function testSupportsAggregateCountFunctionWithSimpleArithmetic()
320
    {
321
        $connMock = $this->_em->getConnection();
322
        $orgPlatform = $connMock->getDatabasePlatform();
323
324
        $connMock->setDatabasePlatform(new MySqlPlatform());
325
326
        $this->assertSqlGeneration(
327
            'SELECT COUNT(CONCAT(u.id, u.name)) FROM Doctrine\Tests\Models\CMS\CmsUser u GROUP BY u.id',
328
            'SELECT COUNT(CONCAT(c0_.id, c0_.name)) AS sclr_0 FROM cms_users c0_ GROUP BY c0_.id'
329
        );
330
331
        $connMock->setDatabasePlatform($orgPlatform);
332
    }
333
334
    public function testSupportsWhereClauseWithPositionalParameter()
335
    {
336
        $this->assertSqlGeneration(
337
            'select u from Doctrine\Tests\Models\Forum\ForumUser u where u.id = ?1',
338
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ WHERE f0_.id = ?'
339
        );
340
    }
341
342
    public function testSupportsWhereClauseWithNamedParameter()
343
    {
344
        $this->assertSqlGeneration(
345
            'select u from Doctrine\Tests\Models\Forum\ForumUser u where u.username = :name',
346
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ WHERE f0_.username = ?'
347
        );
348
    }
349
350
    public function testSupportsWhereAndClauseWithNamedParameters()
351
    {
352
        $this->assertSqlGeneration(
353
            'select u from Doctrine\Tests\Models\Forum\ForumUser u where u.username = :name and u.username = :name2',
354
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ WHERE f0_.username = ? AND f0_.username = ?'
355
        );
356
    }
357
358
    public function testSupportsCombinedWhereClauseWithNamedParameter()
359
    {
360
        $this->assertSqlGeneration(
361
            'select u from Doctrine\Tests\Models\Forum\ForumUser u where (u.username = :name OR u.username = :name2) AND u.id = :id',
362
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ WHERE (f0_.username = ? OR f0_.username = ?) AND f0_.id = ?'
363
        );
364
    }
365
366
    public function testSupportsAggregateFunctionInASelectDistinct()
367
    {
368
        $this->assertSqlGeneration(
369
            'SELECT COUNT(DISTINCT u.name) FROM Doctrine\Tests\Models\CMS\CmsUser u',
370
            'SELECT COUNT(DISTINCT c0_.name) AS sclr_0 FROM cms_users c0_'
371
        );
372
    }
373
374
    // Ticket #668
375
    public function testSupportsASqlKeywordInAStringLiteralParam()
376
    {
377
        $this->assertSqlGeneration(
378
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.name LIKE '%foo OR bar%'",
379
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE c0_.name LIKE '%foo OR bar%'"
380
        );
381
    }
382
383
    public function testSupportsArithmeticExpressionsInWherePart()
384
    {
385
        $this->assertSqlGeneration(
386
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE ((u.id + 5000) * u.id + 3) < 10000000',
387
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE ((c0_.id + 5000) * c0_.id + 3) < 10000000'
388
        );
389
    }
390
391
    public function testSupportsMultipleEntitiesInFromClause()
392
    {
393
        $this->assertSqlGeneration(
394
            'SELECT u, a FROM Doctrine\Tests\Models\CMS\CmsUser u, Doctrine\Tests\Models\CMS\CmsArticle a JOIN a.user u2 WHERE u.id = u2.id',
395
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c1_.id AS id_4, c1_.topic AS topic_5, c1_.text AS text_6, c1_.version AS version_7 FROM cms_users c0_, cms_articles c1_ INNER JOIN cms_users c2_ ON c1_.user_id = c2_.id WHERE c0_.id = c2_.id'
396
        );
397
    }
398
399
    public function testSupportsMultipleEntitiesInFromClauseUsingPathExpression()
400
    {
401
        $this->assertSqlGeneration(
402
            'SELECT u, a FROM Doctrine\Tests\Models\CMS\CmsUser u, Doctrine\Tests\Models\CMS\CmsArticle a WHERE u.id = a.user',
403
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c1_.id AS id_4, c1_.topic AS topic_5, c1_.text AS text_6, c1_.version AS version_7 FROM cms_users c0_, cms_articles c1_ WHERE c0_.id = c1_.user_id'
404
        );
405
    }
406
407
    public function testSupportsPlainJoinWithoutClause()
408
    {
409
        $this->assertSqlGeneration(
410
            'SELECT u.id, a.id from Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN u.articles a',
411
            'SELECT c0_.id AS id_0, c1_.id AS id_1 FROM cms_users c0_ LEFT JOIN cms_articles c1_ ON c0_.id = c1_.user_id'
412
        );
413
        $this->assertSqlGeneration(
414
            'SELECT u.id, a.id from Doctrine\Tests\Models\CMS\CmsUser u JOIN u.articles a',
415
            'SELECT c0_.id AS id_0, c1_.id AS id_1 FROM cms_users c0_ INNER JOIN cms_articles c1_ ON c0_.id = c1_.user_id'
416
        );
417
    }
418
419
    /**
420
     * @group DDC-135
421
     */
422
    public function testSupportsJoinAndWithClauseRestriction()
423
    {
424
        $this->assertSqlGeneration(
425
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN u.articles a WITH a.topic LIKE '%foo%'",
426
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ LEFT JOIN cms_articles c1_ ON c0_.id = c1_.user_id AND (c1_.topic LIKE '%foo%')"
427
        );
428
        $this->assertSqlGeneration(
429
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u INNER JOIN u.articles a WITH a.topic LIKE '%foo%'",
430
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ INNER JOIN cms_articles c1_ ON c0_.id = c1_.user_id AND (c1_.topic LIKE '%foo%')"
431
        );
432
    }
433
434
    /**
435
     * @group DDC-135
436
     * @group DDC-177
437
     */
438
    public function testJoinOnClause_NotYetSupported_ThrowsException()
439
    {
440
        $this->expectException(QueryException::class);
441
442
        $sql = $this->_em->createQuery(
0 ignored issues
show
Unused Code introduced by
The assignment to $sql is dead and can be removed.
Loading history...
443
            "SELECT u, a FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN u.articles a ON a.topic LIKE '%foo%'"
444
        )->getSql();
445
    }
446
447
    public function testSupportsMultipleJoins()
448
    {
449
        $this->assertSqlGeneration(
450
            'SELECT u.id, a.id, p.phonenumber, c.id from Doctrine\Tests\Models\CMS\CmsUser u JOIN u.articles a JOIN u.phonenumbers p JOIN a.comments c',
451
            'SELECT c0_.id AS id_0, c1_.id AS id_1, c2_.phonenumber AS phonenumber_2, c3_.id AS id_3 FROM cms_users c0_ INNER JOIN cms_articles c1_ ON c0_.id = c1_.user_id INNER JOIN cms_phonenumbers c2_ ON c0_.id = c2_.user_id INNER JOIN cms_comments c3_ ON c1_.id = c3_.article_id'
452
        );
453
    }
454
455
    public function testSupportsTrimFunction()
456
    {
457
        $this->assertSqlGeneration(
458
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE TRIM(TRAILING ' ' FROM u.name) = 'someone'",
459
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE TRIM(TRAILING ' ' FROM c0_.name) = 'someone'"
460
        );
461
    }
462
463
    /**
464
     * @group DDC-2668
465
     */
466
    public function testSupportsTrimLeadingZeroString()
467
    {
468
        $this->assertSqlGeneration(
469
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE TRIM(TRAILING '0' FROM u.name) != ''",
470
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE TRIM(TRAILING '0' FROM c0_.name) <> ''"
471
        );
472
    }
473
474
    // Ticket 894
475
    public function testSupportsBetweenClauseWithPositionalParameters()
476
    {
477
        $this->assertSqlGeneration(
478
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id BETWEEN ?1 AND ?2",
479
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE c0_.id BETWEEN ? AND ?"
480
        );
481
    }
482
483
    /**
484
     * @group DDC-1802
485
     */
486
    public function testSupportsNotBetweenForSizeFunction()
487
    {
488
        $this->assertSqlGeneration(
489
            "SELECT m.name FROM Doctrine\Tests\Models\StockExchange\Market m WHERE SIZE(m.stocks) NOT BETWEEN ?1 AND ?2",
490
            "SELECT e0_.name AS name_0 FROM exchange_markets e0_ WHERE (SELECT COUNT(*) FROM exchange_stocks e1_ WHERE e1_.market_id = e0_.id) NOT BETWEEN ? AND ?"
491
        );
492
    }
493
494
    public function testSupportsFunctionalExpressionsInWherePart()
495
    {
496
        $this->assertSqlGeneration(
497
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE TRIM(u.name) = 'someone'",
498
            // String quoting in the SQL usually depends on the database platform.
499
            // This test works with a mock connection which uses ' for string quoting.
500
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE TRIM(c0_.name) = 'someone'"
501
        );
502
    }
503
504
    public function testSupportsInstanceOfExpressionsInWherePart()
505
    {
506
        $this->assertSqlGeneration(
507
            "SELECT u FROM Doctrine\Tests\Models\Company\CompanyPerson u WHERE u INSTANCE OF Doctrine\Tests\Models\Company\CompanyEmployee",
508
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c0_.discr AS discr_2 FROM company_persons c0_ WHERE c0_.discr IN ('manager', 'employee')"
509
        );
510
    }
511
512
    public function testSupportsInstanceOfExpressionInWherePartWithMultipleValues()
513
    {
514
        // This also uses FQCNs starting with or without a backslash in the INSTANCE OF parameter
515
        $this->assertSqlGeneration(
516
            "SELECT u FROM Doctrine\Tests\Models\Company\CompanyPerson u WHERE u INSTANCE OF (Doctrine\Tests\Models\Company\CompanyEmployee, \Doctrine\Tests\Models\Company\CompanyManager)",
517
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c0_.discr AS discr_2 FROM company_persons c0_ WHERE c0_.discr IN ('manager', 'employee')"
518
        );
519
    }
520
521
    /**
522
     * @group DDC-1194
523
     */
524
    public function testSupportsInstanceOfExpressionsInWherePartPrefixedSlash()
525
    {
526
        $this->assertSqlGeneration(
527
            "SELECT u FROM Doctrine\Tests\Models\Company\CompanyPerson u WHERE u INSTANCE OF \Doctrine\Tests\Models\Company\CompanyEmployee",
528
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c0_.discr AS discr_2 FROM company_persons c0_ WHERE c0_.discr IN ('manager', 'employee')"
529
        );
530
    }
531
532
    /**
533
     * @group DDC-1194
534
     */
535
    public function testSupportsInstanceOfExpressionsInWherePartWithUnrelatedClass()
536
    {
537
        $this->assertInvalidSqlGeneration(
538
            "SELECT u FROM Doctrine\Tests\Models\Company\CompanyPerson u WHERE u INSTANCE OF \Doctrine\Tests\Models\CMS\CmsUser",
539
            QueryException::class
540
        );
541
    }
542
543
    public function testSupportsInstanceOfExpressionsInWherePartInDeeperLevel()
544
    {
545
        $this->assertSqlGeneration(
546
            "SELECT u FROM Doctrine\Tests\Models\Company\CompanyEmployee u WHERE u INSTANCE OF Doctrine\Tests\Models\Company\CompanyManager",
547
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c0_.discr AS discr_5 FROM company_employees c1_ INNER JOIN company_persons c0_ ON c1_.id = c0_.id WHERE c0_.discr IN ('manager')"
548
        );
549
    }
550
551
    public function testSupportsInstanceOfExpressionsInWherePartInDeepestLevel()
552
    {
553
        $this->assertSqlGeneration(
554
            "SELECT u FROM Doctrine\Tests\Models\Company\CompanyManager u WHERE u INSTANCE OF Doctrine\Tests\Models\Company\CompanyManager",
555
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c2_.title AS title_5, c0_.discr AS discr_6 FROM company_managers c2_ INNER JOIN company_employees c1_ ON c2_.id = c1_.id INNER JOIN company_persons c0_ ON c2_.id = c0_.id WHERE c0_.discr IN ('manager')"
556
        );
557
    }
558
559
    public function testSupportsInstanceOfExpressionsUsingInputParameterInWherePart()
560
    {
561
        $this->assertSqlGeneration(
562
            "SELECT u FROM Doctrine\Tests\Models\Company\CompanyPerson u WHERE u INSTANCE OF ?1",
563
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c0_.discr AS discr_2 FROM company_persons c0_ WHERE c0_.discr IN (?)",
564
            [], [1 => $this->_em->getClassMetadata(CompanyEmployee::class)]
565
        );
566
    }
567
568
    // Ticket #973
569
    public function testSupportsSingleValuedInExpressionWithoutSpacesInWherePart()
570
    {
571
        $this->assertSqlGeneration(
572
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE IDENTITY(u.email) IN(46)",
573
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE c0_.email_id IN (46)"
574
        );
575
    }
576
577
    public function testSupportsMultipleValuedInExpressionInWherePart()
578
    {
579
        $this->assertSqlGeneration(
580
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id IN (1, 2)',
581
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.id IN (1, 2)'
582
        );
583
    }
584
585
    public function testSupportsNotInExpressionInWherePart()
586
    {
587
        $this->assertSqlGeneration(
588
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE :id NOT IN (1)',
589
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE ? NOT IN (1)'
590
        );
591
    }
592
593
    /**
594
     * @group DDC-1802
595
     */
596
    public function testSupportsNotInExpressionForModFunction()
597
    {
598
        $this->assertSqlGeneration(
599
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE MOD(u.id, 5) NOT IN(1,3,4)",
600
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE MOD(c0_.id, 5) NOT IN (1, 3, 4)"
601
        );
602
    }
603
604
    public function testInExpressionWithSingleValuedAssociationPathExpressionInWherePart()
605
    {
606
        $this->assertSqlGeneration(
607
            'SELECT u FROM Doctrine\Tests\Models\Forum\ForumUser u WHERE u.avatar IN (?1, ?2)',
608
            'SELECT f0_.id AS id_0, f0_.username AS username_1 FROM forum_users f0_ WHERE f0_.avatar_id IN (?, ?)'
609
        );
610
    }
611
612
    public function testInvalidInExpressionWithSingleValuedAssociationPathExpressionOnInverseSide()
613
    {
614
        // We do not support SingleValuedAssociationPathExpression on inverse side
615
        $this->assertInvalidSqlGeneration(
616
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.address IN (?1, ?2)",
617
            QueryException::class
618
        );
619
    }
620
621
    public function testSupportsConcatFunctionForMysqlAndPostgresql()
622
    {
623
        $connMock = $this->_em->getConnection();
624
        $orgPlatform = $connMock->getDatabasePlatform();
625
626
        $connMock->setDatabasePlatform(new MySqlPlatform());
627
        $this->assertSqlGeneration(
628
            "SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE CONCAT(u.name, 's') = ?1",
629
            "SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE CONCAT(c0_.name, 's') = ?"
630
        );
631
        $this->assertSqlGeneration(
632
            "SELECT CONCAT(u.id, u.name) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = ?1",
633
            "SELECT CONCAT(c0_.id, c0_.name) AS sclr_0 FROM cms_users c0_ WHERE c0_.id = ?"
634
        );
635
636
        $connMock->setDatabasePlatform(new PostgreSqlPlatform());
637
        $this->assertSqlGeneration(
638
            "SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE CONCAT(u.name, 's') = ?1",
639
            "SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE c0_.name || 's' = ?"
640
        );
641
        $this->assertSqlGeneration(
642
            "SELECT CONCAT(u.id, u.name) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = ?1",
643
            "SELECT c0_.id || c0_.name AS sclr_0 FROM cms_users c0_ WHERE c0_.id = ?"
644
        );
645
646
        $connMock->setDatabasePlatform($orgPlatform);
647
    }
648
649
    public function testSupportsExistsExpressionInWherePartWithCorrelatedSubquery()
650
    {
651
        $this->assertSqlGeneration(
652
            'SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE EXISTS (SELECT p.phonenumber FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p WHERE p.phonenumber = u.id)',
653
            'SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE EXISTS (SELECT c1_.phonenumber FROM cms_phonenumbers c1_ WHERE c1_.phonenumber = c0_.id)'
654
        );
655
    }
656
657
    /**
658
     * @group DDC-593
659
     */
660
    public function testSubqueriesInComparisonExpression()
661
    {
662
        $this->assertSqlGeneration(
663
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE (u.id >= (SELECT u2.id FROM Doctrine\Tests\Models\CMS\CmsUser u2 WHERE u2.name = :name)) AND (u.id <= (SELECT u3.id FROM Doctrine\Tests\Models\CMS\CmsUser u3 WHERE u3.name = :name))',
664
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (c0_.id >= (SELECT c1_.id FROM cms_users c1_ WHERE c1_.name = ?)) AND (c0_.id <= (SELECT c2_.id FROM cms_users c2_ WHERE c2_.name = ?))'
665
        );
666
    }
667
668
    public function testSupportsMemberOfExpressionOneToMany()
669
    {
670
        // "Get all users who have $phone as a phonenumber." (*cough* doesnt really make sense...)
671
        $q = $this->_em->createQuery('SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE :param MEMBER OF u.phonenumbers');
672
        $q->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true);
673
674
        $phone = new CmsPhonenumber();
675
        $phone->phonenumber = 101;
676
        $q->setParameter('param', $phone);
677
678
        $this->assertEquals(
679
            'SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE EXISTS (SELECT 1 FROM cms_phonenumbers c1_ WHERE c0_.id = c1_.user_id AND c1_.phonenumber = ?)',
680
            $q->getSql()
681
        );
682
    }
683
684
    public function testSupportsMemberOfExpressionManyToMany()
685
    {
686
        // "Get all users who are members of $group."
687
        $q = $this->_em->createQuery('SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE :param MEMBER OF u.groups');
688
        $q->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true);
689
690
        $group = new CmsGroup();
691
        $group->id = 101;
692
        $q->setParameter('param', $group);
693
694
        $this->assertEquals(
695
            'SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE EXISTS (SELECT 1 FROM cms_users_groups c1_ INNER JOIN cms_groups c2_ ON c1_.group_id = c2_.id WHERE c1_.user_id = c0_.id AND c2_.id IN (?))',
696
            $q->getSql()
697
        );
698
    }
699
700
    public function testSupportsMemberOfExpressionManyToManyParameterArray()
701
    {
702
        $q = $this->_em->createQuery('SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE :param MEMBER OF u.groups');
703
        $q->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true);
704
705
        $group = new CmsGroup();
706
        $group->id = 101;
707
        $group2 = new CmsGroup();
708
        $group2->id = 105;
709
        $q->setParameter('param', [$group, $group2]);
710
711
        $this->assertEquals(
712
            'SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE EXISTS (SELECT 1 FROM cms_users_groups c1_ INNER JOIN cms_groups c2_ ON c1_.group_id = c2_.id WHERE c1_.user_id = c0_.id AND c2_.id IN (?))',
713
            $q->getSql()
714
        );
715
    }
716
717
    public function testSupportsMemberOfExpressionSelfReferencing()
718
    {
719
        // "Get all persons who have $person as a friend."
720
        // Tough one: Many-many self-referencing ("friends") with class table inheritance
721
        $q = $this->_em->createQuery('SELECT p FROM Doctrine\Tests\Models\Company\CompanyPerson p WHERE :param MEMBER OF p.friends');
722
        $person = new CompanyPerson();
723
        $this->_em->getClassMetadata(get_class($person))->setIdentifierValues($person, ['id' => 101]);
724
        $q->setParameter('param', $person);
725
        $this->assertEquals(
726
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.title AS title_2, c2_.salary AS salary_3, c2_.department AS department_4, c2_.startDate AS startDate_5, c0_.discr AS discr_6, c0_.spouse_id AS spouse_id_7, c1_.car_id AS car_id_8 FROM company_persons c0_ LEFT JOIN company_managers c1_ ON c0_.id = c1_.id LEFT JOIN company_employees c2_ ON c0_.id = c2_.id WHERE EXISTS (SELECT 1 FROM company_persons_friends c3_ INNER JOIN company_persons c4_ ON c3_.friend_id = c4_.id WHERE c3_.person_id = c0_.id AND c4_.id IN (?))',
727
            $q->getSql()
728
        );
729
    }
730
731
    public function testSupportsMemberOfWithSingleValuedAssociation()
732
    {
733
        // Impossible example, but it illustrates the purpose
734
        $q = $this->_em->createQuery('SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.email MEMBER OF u.groups');
735
736
        $this->assertEquals(
737
            'SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE EXISTS (SELECT 1 FROM cms_users_groups c1_ INNER JOIN cms_groups c2_ ON c1_.group_id = c2_.id WHERE c1_.user_id = c0_.id AND c2_.id IN (c0_.email_id))',
738
            $q->getSql()
739
        );
740
    }
741
742
    public function testSupportsMemberOfWithIdentificationVariable()
743
    {
744
        // Impossible example, but it illustrates the purpose
745
        $q = $this->_em->createQuery('SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u MEMBER OF u.groups');
746
747
        $this->assertEquals(
748
            'SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE EXISTS (SELECT 1 FROM cms_users_groups c1_ INNER JOIN cms_groups c2_ ON c1_.group_id = c2_.id WHERE c1_.user_id = c0_.id AND c2_.id IN (c0_.id))',
749
            $q->getSql()
750
        );
751
    }
752
753
    public function testSupportsCurrentDateFunction()
754
    {
755
        $q = $this->_em->createQuery('SELECT d.id FROM Doctrine\Tests\Models\Generic\DateTimeModel d WHERE d.datetime > current_date()');
756
        $q->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true);
757
        $this->assertEquals('SELECT d0_.id AS id_0 FROM date_time_model d0_ WHERE d0_.col_datetime > CURRENT_DATE', $q->getSql());
758
    }
759
760
    public function testSupportsCurrentTimeFunction()
761
    {
762
        $q = $this->_em->createQuery('SELECT d.id FROM Doctrine\Tests\Models\Generic\DateTimeModel d WHERE d.time > current_time()');
763
        $q->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true);
764
        $this->assertEquals('SELECT d0_.id AS id_0 FROM date_time_model d0_ WHERE d0_.col_time > CURRENT_TIME', $q->getSql());
765
    }
766
767
    public function testSupportsCurrentTimestampFunction()
768
    {
769
        $q = $this->_em->createQuery('SELECT d.id FROM Doctrine\Tests\Models\Generic\DateTimeModel d WHERE d.datetime > current_timestamp()');
770
        $q->setHint(ORMQuery::HINT_FORCE_PARTIAL_LOAD, true);
771
        $this->assertEquals('SELECT d0_.id AS id_0 FROM date_time_model d0_ WHERE d0_.col_datetime > CURRENT_TIMESTAMP', $q->getSql());
772
    }
773
774
    public function testExistsExpressionInWhereCorrelatedSubqueryAssocCondition()
775
    {
776
        $this->assertSqlGeneration(
777
            // DQL
778
            // The result of this query consists of all employees whose spouses are also employees.
779
            'SELECT DISTINCT emp FROM Doctrine\Tests\Models\CMS\CmsEmployee emp
780
                WHERE EXISTS (
781
                    SELECT spouseEmp
782
                    FROM Doctrine\Tests\Models\CMS\CmsEmployee spouseEmp
783
                    WHERE spouseEmp = emp.spouse)',
784
            // SQL
785
            'SELECT DISTINCT c0_.id AS id_0, c0_.name AS name_1 FROM cms_employees c0_'
786
                . ' WHERE EXISTS ('
787
                    . 'SELECT c1_.id FROM cms_employees c1_ WHERE c1_.id = c0_.spouse_id'
788
                    . ')'
789
        );
790
    }
791
792
    public function testExistsExpressionWithSimpleSelectReturningScalar()
793
    {
794
        $this->assertSqlGeneration(
795
            // DQL
796
            // The result of this query consists of all employees whose spouses are also employees.
797
            'SELECT DISTINCT emp FROM Doctrine\Tests\Models\CMS\CmsEmployee emp
798
                WHERE EXISTS (
799
                    SELECT 1
800
                    FROM Doctrine\Tests\Models\CMS\CmsEmployee spouseEmp
801
                    WHERE spouseEmp = emp.spouse)',
802
            // SQL
803
            'SELECT DISTINCT c0_.id AS id_0, c0_.name AS name_1 FROM cms_employees c0_'
804
                . ' WHERE EXISTS ('
805
                    . 'SELECT 1 AS sclr_2 FROM cms_employees c1_ WHERE c1_.id = c0_.spouse_id'
806
                    . ')'
807
        );
808
    }
809
810
    public function testLimitFromQueryClass()
811
    {
812
        $q = $this->_em
813
            ->createQuery('SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u')
814
            ->setMaxResults(10);
815
816
        $this->assertEquals('SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c0_.email_id AS email_id_4 FROM cms_users c0_ LIMIT 10', $q->getSql());
817
    }
818
819
    public function testLimitAndOffsetFromQueryClass()
820
    {
821
        $q = $this->_em
822
            ->createQuery('SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u')
823
            ->setMaxResults(10)
824
            ->setFirstResult(0);
825
826
        $this->assertEquals('SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c0_.email_id AS email_id_4 FROM cms_users c0_ LIMIT 10 OFFSET 0', $q->getSql());
827
    }
828
829
    public function testSizeFunction()
830
    {
831
        $this->assertSqlGeneration(
832
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE SIZE(u.phonenumbers) > 1",
833
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (SELECT COUNT(*) FROM cms_phonenumbers c1_ WHERE c1_.user_id = c0_.id) > 1"
834
        );
835
    }
836
837
    public function testSizeFunctionSupportsManyToMany()
838
    {
839
        $this->assertSqlGeneration(
840
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE SIZE(u.groups) > 1",
841
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (SELECT COUNT(*) FROM cms_users_groups c1_ WHERE c1_.user_id = c0_.id) > 1"
842
        );
843
    }
844
845
    public function testEmptyCollectionComparisonExpression()
846
    {
847
        $this->assertSqlGeneration(
848
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.phonenumbers IS EMPTY",
849
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (SELECT COUNT(*) FROM cms_phonenumbers c1_ WHERE c1_.user_id = c0_.id) = 0"
850
        );
851
        $this->assertSqlGeneration(
852
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.phonenumbers IS NOT EMPTY",
853
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (SELECT COUNT(*) FROM cms_phonenumbers c1_ WHERE c1_.user_id = c0_.id) > 0"
854
        );
855
    }
856
857
    public function testNestedExpressions()
858
    {
859
        $this->assertSqlGeneration(
860
            "select u from Doctrine\Tests\Models\CMS\CmsUser u where u.id > 10 and u.id < 42 and ((u.id * 2) > 5)",
861
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.id > 10 AND c0_.id < 42 AND ((c0_.id * 2) > 5)"
862
        );
863
    }
864
865
    public function testNestedExpressions2()
866
    {
867
        $this->assertSqlGeneration(
868
            "select u from Doctrine\Tests\Models\CMS\CmsUser u where (u.id > 10) and (u.id < 42 and ((u.id * 2) > 5)) or u.id <> 42",
869
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (c0_.id > 10) AND (c0_.id < 42 AND ((c0_.id * 2) > 5)) OR c0_.id <> 42"
870
        );
871
    }
872
873
    public function testNestedExpressions3()
874
    {
875
        $this->assertSqlGeneration(
876
            "select u from Doctrine\Tests\Models\CMS\CmsUser u where (u.id > 10) and (u.id between 1 and 10 or u.id in (1, 2, 3, 4, 5))",
877
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (c0_.id > 10) AND (c0_.id BETWEEN 1 AND 10 OR c0_.id IN (1, 2, 3, 4, 5))"
878
        );
879
    }
880
881
    public function testOrderByCollectionAssociationSize()
882
    {
883
        $this->assertSqlGeneration(
884
            "select u, size(u.articles) as numArticles from Doctrine\Tests\Models\CMS\CmsUser u order by numArticles",
885
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, (SELECT COUNT(*) FROM cms_articles c1_ WHERE c1_.user_id = c0_.id) AS sclr_4 FROM cms_users c0_ ORDER BY sclr_4 ASC"
886
        );
887
    }
888
889
    public function testOrderBySupportsSingleValuedPathExpressionOwningSide()
890
    {
891
        $this->assertSqlGeneration(
892
            "select a from Doctrine\Tests\Models\CMS\CmsArticle a order by a.user",
893
            "SELECT c0_.id AS id_0, c0_.topic AS topic_1, c0_.text AS text_2, c0_.version AS version_3 FROM cms_articles c0_ ORDER BY c0_.user_id ASC"
894
        );
895
    }
896
897
    /**
898
     * @expectedException \Doctrine\ORM\Query\QueryException
899
     */
900
    public function testOrderBySupportsSingleValuedPathExpressionInverseSide()
901
    {
902
        $q = $this->_em->createQuery("select u from Doctrine\Tests\Models\CMS\CmsUser u order by u.address");
903
        $q->getSQL();
904
    }
905
906
    public function testBooleanLiteralInWhereOnSqlite()
907
    {
908
        $oldPlat = $this->_em->getConnection()->getDatabasePlatform();
909
        $this->_em->getConnection()->setDatabasePlatform(new SqlitePlatform());
910
911
        $this->assertSqlGeneration(
912
            "SELECT b FROM Doctrine\Tests\Models\Generic\BooleanModel b WHERE b.booleanField = true",
913
            "SELECT b0_.id AS id_0, b0_.booleanField AS booleanField_1 FROM boolean_model b0_ WHERE b0_.booleanField = 1"
914
        );
915
916
        $this->assertSqlGeneration(
917
            "SELECT b FROM Doctrine\Tests\Models\Generic\BooleanModel b WHERE b.booleanField = false",
918
            "SELECT b0_.id AS id_0, b0_.booleanField AS booleanField_1 FROM boolean_model b0_ WHERE b0_.booleanField = 0"
919
        );
920
921
        $this->_em->getConnection()->setDatabasePlatform($oldPlat);
922
    }
923
924
    public function testBooleanLiteralInWhereOnPostgres()
925
    {
926
        $oldPlat = $this->_em->getConnection()->getDatabasePlatform();
927
        $this->_em->getConnection()->setDatabasePlatform(new PostgreSqlPlatform());
928
929
        $this->assertSqlGeneration(
930
            "SELECT b FROM Doctrine\Tests\Models\Generic\BooleanModel b WHERE b.booleanField = true",
931
            "SELECT b0_.id AS id_0, b0_.booleanField AS booleanfield_1 FROM boolean_model b0_ WHERE b0_.booleanField = true"
932
        );
933
934
        $this->assertSqlGeneration(
935
            "SELECT b FROM Doctrine\Tests\Models\Generic\BooleanModel b WHERE b.booleanField = false",
936
            "SELECT b0_.id AS id_0, b0_.booleanField AS booleanfield_1 FROM boolean_model b0_ WHERE b0_.booleanField = false"
937
        );
938
939
        $this->_em->getConnection()->setDatabasePlatform($oldPlat);
940
    }
941
942
    public function testSingleValuedAssociationFieldInWhere()
943
    {
944
        $this->assertSqlGeneration(
945
            "SELECT p FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p WHERE p.user = ?1",
946
            "SELECT c0_.phonenumber AS phonenumber_0 FROM cms_phonenumbers c0_ WHERE c0_.user_id = ?"
947
        );
948
    }
949
950
    public function testSingleValuedAssociationNullCheckOnOwningSide()
951
    {
952
        $this->assertSqlGeneration(
953
            "SELECT a FROM Doctrine\Tests\Models\CMS\CmsAddress a WHERE a.user IS NULL",
954
            "SELECT c0_.id AS id_0, c0_.country AS country_1, c0_.zip AS zip_2, c0_.city AS city_3 FROM cms_addresses c0_ WHERE c0_.user_id IS NULL"
955
        );
956
    }
957
958
    // Null check on inverse side has to happen through explicit JOIN.
959
    // "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.address IS NULL"
960
    // where the CmsUser is the inverse side is not supported.
961
    public function testSingleValuedAssociationNullCheckOnInverseSide()
962
    {
963
        $this->assertSqlGeneration(
964
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN u.address a WHERE a.id IS NULL",
965
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ LEFT JOIN cms_addresses c1_ ON c0_.id = c1_.user_id WHERE c1_.id IS NULL"
966
        );
967
    }
968
969
    /**
970
     * @group DDC-339
971
     * @group DDC-1572
972
     */
973
    public function testStringFunctionLikeExpression()
974
    {
975
        $this->assertSqlGeneration(
976
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE LOWER(u.name) LIKE '%foo OR bar%'",
977
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE LOWER(c0_.name) LIKE '%foo OR bar%'"
978
        );
979
        $this->assertSqlGeneration(
980
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE LOWER(u.name) LIKE :str",
981
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE LOWER(c0_.name) LIKE ?"
982
        );
983
        $this->assertSqlGeneration(
984
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE CONCAT(UPPER(u.name), '_moo') LIKE :str",
985
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE UPPER(c0_.name) || '_moo' LIKE ?"
986
        );
987
988
        // DDC-1572
989
        $this->assertSqlGeneration(
990
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE UPPER(u.name) LIKE UPPER(:str)",
991
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE UPPER(c0_.name) LIKE UPPER(?)"
992
        );
993
        $this->assertSqlGeneration(
994
            "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE UPPER(LOWER(u.name)) LIKE UPPER(LOWER(:str))",
995
            "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE UPPER(LOWER(c0_.name)) LIKE UPPER(LOWER(?))"
996
        );
997
        $this->assertSqlGeneration(
998
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN u.articles a WITH a.topic LIKE u.name",
999
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ LEFT JOIN cms_articles c1_ ON c0_.id = c1_.user_id AND (c1_.topic LIKE c0_.name)"
1000
        );
1001
    }
1002
1003
    /**
1004
     * @group DDC-1802
1005
     */
1006
    public function testStringFunctionNotLikeExpression()
1007
    {
1008
        $this->assertSqlGeneration(
1009
                "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE LOWER(u.name) NOT LIKE '%foo OR bar%'",
1010
                "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE LOWER(c0_.name) NOT LIKE '%foo OR bar%'"
1011
        );
1012
1013
        $this->assertSqlGeneration(
1014
                "SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE UPPER(LOWER(u.name)) NOT LIKE UPPER(LOWER(:str))",
1015
                "SELECT c0_.name AS name_0 FROM cms_users c0_ WHERE UPPER(LOWER(c0_.name)) NOT LIKE UPPER(LOWER(?))"
1016
        );
1017
        $this->assertSqlGeneration(
1018
                "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN u.articles a WITH a.topic NOT LIKE u.name",
1019
                "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ LEFT JOIN cms_articles c1_ ON c0_.id = c1_.user_id AND (c1_.topic NOT LIKE c0_.name)"
1020
        );
1021
    }
1022
1023
    /**
1024
     * @group DDC-338
1025
     */
1026
    public function testOrderedCollectionFetchJoined()
1027
    {
1028
        $this->assertSqlGeneration(
1029
            "SELECT r, l FROM Doctrine\Tests\Models\Routing\RoutingRoute r JOIN r.legs l",
1030
            "SELECT r0_.id AS id_0, r1_.id AS id_1, r1_.departureDate AS departureDate_2, r1_.arrivalDate AS arrivalDate_3 FROM RoutingRoute r0_ INNER JOIN RoutingRouteLegs r2_ ON r0_.id = r2_.route_id INNER JOIN RoutingLeg r1_ ON r1_.id = r2_.leg_id ".
1031
            "ORDER BY r1_.departureDate ASC"
1032
        );
1033
    }
1034
1035
    public function testSubselectInSelect()
1036
    {
1037
        $this->assertSqlGeneration(
1038
            "SELECT u.name, (SELECT COUNT(p.phonenumber) FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p WHERE p.phonenumber = 1234) pcount FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.name = 'jon'",
1039
            "SELECT c0_.name AS name_0, (SELECT COUNT(c1_.phonenumber) AS sclr_2 FROM cms_phonenumbers c1_ WHERE c1_.phonenumber = 1234) AS sclr_1 FROM cms_users c0_ WHERE c0_.name = 'jon'"
1040
        );
1041
    }
1042
1043
    /**
1044
     * @group locking
1045
     * @group DDC-178
1046
     */
1047
    public function testPessimisticWriteLockQueryHint()
1048
    {
1049
        if ($this->_em->getConnection()->getDatabasePlatform() instanceof SqlitePlatform) {
1050
            $this->markTestSkipped('SqLite does not support Row locking at all.');
1051
        }
1052
1053
        $this->assertSqlGeneration(
1054
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.username = 'gblanco'",
1055
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 ".
1056
            "FROM cms_users c0_ WHERE c0_.username = 'gblanco' FOR UPDATE",
1057
            [ORMQuery::HINT_LOCK_MODE => LockMode::PESSIMISTIC_WRITE]
1058
        );
1059
    }
1060
1061
    /**
1062
     * @group locking
1063
     * @group DDC-178
1064
     */
1065
    public function testPessimisticReadLockQueryHintPostgreSql()
1066
    {
1067
        $this->_em->getConnection()->setDatabasePlatform(new PostgreSqlPlatform());
1068
1069
        $this->assertSqlGeneration(
1070
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.username = 'gblanco'",
1071
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 ".
1072
            "FROM cms_users c0_ WHERE c0_.username = 'gblanco' FOR SHARE",
1073
            [ORMQuery::HINT_LOCK_MODE => LockMode::PESSIMISTIC_READ]
1074
        );
1075
    }
1076
1077
    /**
1078
     * @group DDC-1693
1079
     * @group locking
1080
     */
1081
    public function testLockModeNoneQueryHint()
1082
    {
1083
        $this->assertSqlGeneration(
1084
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.username = 'gblanco'",
1085
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 ".
1086
            "FROM cms_users c0_ WHERE c0_.username = 'gblanco'",
1087
            [ORMQuery::HINT_LOCK_MODE => LockMode::NONE]
1088
        );
1089
    }
1090
1091
    /**
1092
     * @group DDC-430
1093
     */
1094
    public function testSupportSelectWithMoreThan10InputParameters()
1095
    {
1096
        $this->assertSqlGeneration(
1097
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = ?1 OR u.id = ?2 OR u.id = ?3 OR u.id = ?4 OR u.id = ?5 OR u.id = ?6 OR u.id = ?7 OR u.id = ?8 OR u.id = ?9 OR u.id = ?10 OR u.id = ?11",
1098
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ? OR c0_.id = ?"
1099
        );
1100
    }
1101
1102
    /**
1103
     * @group locking
1104
     * @group DDC-178
1105
     */
1106
    public function testPessimisticReadLockQueryHintMySql()
1107
    {
1108
        $this->_em->getConnection()->setDatabasePlatform(new MySqlPlatform());
1109
1110
        $this->assertSqlGeneration(
1111
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.username = 'gblanco'",
1112
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 ".
1113
            "FROM cms_users c0_ WHERE c0_.username = 'gblanco' LOCK IN SHARE MODE",
1114
            [ORMQuery::HINT_LOCK_MODE => LockMode::PESSIMISTIC_READ]
1115
        );
1116
    }
1117
1118
    /**
1119
     * @group locking
1120
     * @group DDC-178
1121
     */
1122
    public function testPessimisticReadLockQueryHintOracle()
1123
    {
1124
        $this->_em->getConnection()->setDatabasePlatform(new OraclePlatform());
1125
1126
        $this->assertSqlGeneration(
1127
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.username = 'gblanco'",
1128
            "SELECT c0_.id AS ID_0, c0_.status AS STATUS_1, c0_.username AS USERNAME_2, c0_.name AS NAME_3 ".
1129
            "FROM cms_users c0_ WHERE c0_.username = 'gblanco' FOR UPDATE",
1130
            [ORMQuery::HINT_LOCK_MODE => LockMode::PESSIMISTIC_READ]
1131
        );
1132
    }
1133
1134
    /**
1135
     * @group DDC-431
1136
     */
1137
    public function testSupportToCustomDQLFunctions()
1138
    {
1139
        $config = $this->_em->getConfiguration();
1140
        $config->addCustomNumericFunction('MYABS', MyAbsFunction::class);
1141
1142
        $this->assertSqlGeneration(
1143
            'SELECT MYABS(p.phonenumber) FROM Doctrine\Tests\Models\CMS\CmsPhonenumber p',
1144
            'SELECT ABS(c0_.phonenumber) AS sclr_0 FROM cms_phonenumbers c0_'
1145
        );
1146
1147
        $config->setCustomNumericFunctions([]);
1148
    }
1149
1150
    /**
1151
     * @group DDC-826
1152
     */
1153
    public function testMappedSuperclassAssociationJoin()
1154
    {
1155
        $this->assertSqlGeneration(
1156
            'SELECT f FROM Doctrine\Tests\Models\DirectoryTree\File f JOIN f.parentDirectory d WHERE f.id = ?1',
1157
            'SELECT f0_.id AS id_0, f0_.extension AS extension_1, f0_.name AS name_2 FROM "file" f0_ INNER JOIN Directory d1_ ON f0_.parentDirectory_id = d1_.id WHERE f0_.id = ?'
1158
        );
1159
    }
1160
1161
    /**
1162
     * @group DDC-1053
1163
     */
1164
    public function testGroupBy()
1165
    {
1166
        $this->assertSqlGeneration(
1167
            'SELECT g.id, count(u.id) FROM Doctrine\Tests\Models\CMS\CmsGroup g JOIN g.users u GROUP BY g.id',
1168
            'SELECT c0_.id AS id_0, count(c1_.id) AS sclr_1 FROM cms_groups c0_ INNER JOIN cms_users_groups c2_ ON c0_.id = c2_.group_id INNER JOIN cms_users c1_ ON c1_.id = c2_.user_id GROUP BY c0_.id'
1169
        );
1170
    }
1171
1172
    /**
1173
     * @group DDC-1053
1174
     */
1175
    public function testGroupByIdentificationVariable()
1176
    {
1177
        $this->assertSqlGeneration(
1178
            'SELECT g, count(u.id) FROM Doctrine\Tests\Models\CMS\CmsGroup g JOIN g.users u GROUP BY g',
1179
            'SELECT c0_.id AS id_0, c0_.name AS name_1, count(c1_.id) AS sclr_2 FROM cms_groups c0_ INNER JOIN cms_users_groups c2_ ON c0_.id = c2_.group_id INNER JOIN cms_users c1_ ON c1_.id = c2_.user_id GROUP BY c0_.id, c0_.name'
1180
        );
1181
    }
1182
1183
    public function testCaseContainingNullIf()
1184
    {
1185
        $this->assertSqlGeneration(
1186
            "SELECT NULLIF(g.id, g.name) AS NullIfEqual FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1187
            'SELECT NULLIF(c0_.id, c0_.name) AS sclr_0 FROM cms_groups c0_'
1188
        );
1189
    }
1190
1191
    public function testCaseContainingCoalesce()
1192
    {
1193
        $this->assertSqlGeneration(
1194
            "SELECT COALESCE(NULLIF(u.name, ''), u.username) as Display FROM Doctrine\Tests\Models\CMS\CmsUser u",
1195
            "SELECT COALESCE(NULLIF(c0_.name, ''), c0_.username) AS sclr_0 FROM cms_users c0_"
1196
        );
1197
    }
1198
1199
    /**
1200
     * Test that the right discriminator data is inserted in a subquery.
1201
     */
1202
    public function testSubSelectDiscriminator()
1203
    {
1204
        $this->assertSqlGeneration(
1205
            "SELECT u.name, (SELECT COUNT(cfc.id) total FROM Doctrine\Tests\Models\Company\CompanyFixContract cfc) as cfc_count FROM Doctrine\Tests\Models\CMS\CmsUser u",
1206
            "SELECT c0_.name AS name_0, (SELECT COUNT(c1_.id) AS sclr_2 FROM company_contracts c1_ WHERE c1_.discr IN ('fix')) AS sclr_1 FROM cms_users c0_"
1207
        );
1208
    }
1209
1210
    public function testIdVariableResultVariableReuse()
1211
    {
1212
        $exceptionThrown = false;
1213
        try {
1214
            $query = $this->_em->createQuery("SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.name IN (SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u)");
1215
1216
            $query->getSql();
1217
            $query->free();
1218
        } catch (\Exception $e) {
1219
            $exceptionThrown = true;
1220
        }
1221
1222
        $this->assertTrue($exceptionThrown);
1223
1224
    }
1225
1226
    public function testSubSelectAliasesFromOuterQuery()
1227
    {
1228
        $this->assertSqlGeneration(
1229
            "SELECT uo, (SELECT ui.name FROM Doctrine\Tests\Models\CMS\CmsUser ui WHERE ui.id = uo.id) AS bar FROM Doctrine\Tests\Models\CMS\CmsUser uo",
1230
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, (SELECT c1_.name FROM cms_users c1_ WHERE c1_.id = c0_.id) AS sclr_4 FROM cms_users c0_"
1231
        );
1232
    }
1233
1234
    public function testSubSelectAliasesFromOuterQueryWithSubquery()
1235
    {
1236
        $this->assertSqlGeneration(
1237
            "SELECT uo, (SELECT ui.name FROM Doctrine\Tests\Models\CMS\CmsUser ui WHERE ui.id = uo.id AND ui.name IN (SELECT uii.name FROM Doctrine\Tests\Models\CMS\CmsUser uii)) AS bar FROM Doctrine\Tests\Models\CMS\CmsUser uo",
1238
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, (SELECT c1_.name FROM cms_users c1_ WHERE c1_.id = c0_.id AND c1_.name IN (SELECT c2_.name FROM cms_users c2_)) AS sclr_4 FROM cms_users c0_"
1239
        );
1240
    }
1241
1242
    public function testSubSelectAliasesFromOuterQueryReuseInWhereClause()
1243
    {
1244
        $this->assertSqlGeneration(
1245
            "SELECT uo, (SELECT ui.name FROM Doctrine\Tests\Models\CMS\CmsUser ui WHERE ui.id = uo.id) AS bar FROM Doctrine\Tests\Models\CMS\CmsUser uo WHERE bar = ?0",
1246
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, (SELECT c1_.name FROM cms_users c1_ WHERE c1_.id = c0_.id) AS sclr_4 FROM cms_users c0_ WHERE sclr_4 = ?"
1247
        );
1248
    }
1249
1250
    /**
1251
     * @group DDC-1298
1252
     */
1253
    public function testSelectForeignKeyPKWithoutFields()
1254
    {
1255
        $this->assertSqlGeneration(
1256
            "SELECT t, s, l FROM Doctrine\Tests\Models\DDC117\DDC117Link l INNER JOIN l.target t INNER JOIN l.source s",
1257
            "SELECT d0_.article_id AS article_id_0, d0_.title AS title_1, d1_.article_id AS article_id_2, d1_.title AS title_3, d2_.source_id AS source_id_4, d2_.target_id AS target_id_5 FROM DDC117Link d2_ INNER JOIN DDC117Article d0_ ON d2_.target_id = d0_.article_id INNER JOIN DDC117Article d1_ ON d2_.source_id = d1_.article_id"
1258
        );
1259
    }
1260
1261
    public function testGeneralCaseWithSingleWhenClause()
1262
    {
1263
        $this->assertSqlGeneration(
1264
            "SELECT g.id, CASE WHEN ((g.id / 2) > 18) THEN 1 ELSE 0 END AS test FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1265
            "SELECT c0_.id AS id_0, CASE WHEN ((c0_.id / 2) > 18) THEN 1 ELSE 0 END AS sclr_1 FROM cms_groups c0_"
1266
        );
1267
    }
1268
1269
    public function testGeneralCaseWithMultipleWhenClause()
1270
    {
1271
        $this->assertSqlGeneration(
1272
            "SELECT g.id, CASE WHEN (g.id / 2 < 10) THEN 2 WHEN ((g.id / 2) > 20) THEN 1 ELSE 0 END AS test FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1273
            "SELECT c0_.id AS id_0, CASE WHEN (c0_.id / 2 < 10) THEN 2 WHEN ((c0_.id / 2) > 20) THEN 1 ELSE 0 END AS sclr_1 FROM cms_groups c0_"
1274
        );
1275
    }
1276
1277
    public function testSimpleCaseWithSingleWhenClause()
1278
    {
1279
        $this->assertSqlGeneration(
1280
            "SELECT g FROM Doctrine\Tests\Models\CMS\CmsGroup g WHERE g.id = CASE g.name WHEN 'admin' THEN 1 ELSE 2 END",
1281
            "SELECT c0_.id AS id_0, c0_.name AS name_1 FROM cms_groups c0_ WHERE c0_.id = CASE c0_.name WHEN 'admin' THEN 1 ELSE 2 END"
1282
        );
1283
    }
1284
1285
    public function testSimpleCaseWithMultipleWhenClause()
1286
    {
1287
        $this->assertSqlGeneration(
1288
            "SELECT g FROM Doctrine\Tests\Models\CMS\CmsGroup g WHERE g.id = (CASE g.name WHEN 'admin' THEN 1 WHEN 'moderator' THEN 2 ELSE 3 END)",
1289
            "SELECT c0_.id AS id_0, c0_.name AS name_1 FROM cms_groups c0_ WHERE c0_.id = (CASE c0_.name WHEN 'admin' THEN 1 WHEN 'moderator' THEN 2 ELSE 3 END)"
1290
        );
1291
    }
1292
1293
    public function testGeneralCaseWithSingleWhenClauseInSubselect()
1294
    {
1295
        $this->assertSqlGeneration(
1296
            "SELECT g FROM Doctrine\Tests\Models\CMS\CmsGroup g WHERE g.id IN (SELECT CASE WHEN ((g2.id / 2) > 18) THEN 2 ELSE 1 END FROM Doctrine\Tests\Models\CMS\CmsGroup g2)",
1297
            "SELECT c0_.id AS id_0, c0_.name AS name_1 FROM cms_groups c0_ WHERE c0_.id IN (SELECT CASE WHEN ((c1_.id / 2) > 18) THEN 2 ELSE 1 END AS sclr_2 FROM cms_groups c1_)"
1298
        );
1299
    }
1300
1301
    public function testGeneralCaseWithMultipleWhenClauseInSubselect()
1302
    {
1303
        $this->assertSqlGeneration(
1304
            "SELECT g FROM Doctrine\Tests\Models\CMS\CmsGroup g WHERE g.id IN (SELECT CASE WHEN (g.id / 2 < 10) THEN 3 WHEN ((g.id / 2) > 20) THEN 2 ELSE 1 END FROM Doctrine\Tests\Models\CMS\CmsGroup g2)",
1305
            "SELECT c0_.id AS id_0, c0_.name AS name_1 FROM cms_groups c0_ WHERE c0_.id IN (SELECT CASE WHEN (c0_.id / 2 < 10) THEN 3 WHEN ((c0_.id / 2) > 20) THEN 2 ELSE 1 END AS sclr_2 FROM cms_groups c1_)"
1306
        );
1307
    }
1308
1309
    public function testSimpleCaseWithSingleWhenClauseInSubselect()
1310
    {
1311
        $this->assertSqlGeneration(
1312
            "SELECT g FROM Doctrine\Tests\Models\CMS\CmsGroup g WHERE g.id IN (SELECT CASE g2.name WHEN 'admin' THEN 1 ELSE 2 END FROM Doctrine\Tests\Models\CMS\CmsGroup g2)",
1313
            "SELECT c0_.id AS id_0, c0_.name AS name_1 FROM cms_groups c0_ WHERE c0_.id IN (SELECT CASE c1_.name WHEN 'admin' THEN 1 ELSE 2 END AS sclr_2 FROM cms_groups c1_)"
1314
        );
1315
    }
1316
1317
    public function testSimpleCaseWithMultipleWhenClauseInSubselect()
1318
    {
1319
        $this->assertSqlGeneration(
1320
            "SELECT g FROM Doctrine\Tests\Models\CMS\CmsGroup g WHERE g.id IN (SELECT CASE g2.name WHEN 'admin' THEN 1 WHEN 'moderator' THEN 2 ELSE 3 END FROM Doctrine\Tests\Models\CMS\CmsGroup g2)",
1321
            "SELECT c0_.id AS id_0, c0_.name AS name_1 FROM cms_groups c0_ WHERE c0_.id IN (SELECT CASE c1_.name WHEN 'admin' THEN 1 WHEN 'moderator' THEN 2 ELSE 3 END AS sclr_2 FROM cms_groups c1_)"
1322
        );
1323
    }
1324
1325
    /**
1326
     * @group DDC-1696
1327
     */
1328
    public function testSimpleCaseWithStringPrimary()
1329
    {
1330
        $this->assertSqlGeneration(
1331
            "SELECT g.id, CASE WHEN ((g.id / 2) > 18) THEN 'Foo' ELSE 'Bar' END AS test FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1332
            "SELECT c0_.id AS id_0, CASE WHEN ((c0_.id / 2) > 18) THEN 'Foo' ELSE 'Bar' END AS sclr_1 FROM cms_groups c0_"
1333
        );
1334
    }
1335
1336
    /**
1337
     * @group DDC-2205
1338
     */
1339
    public function testCaseNegativeValuesInThenExpression()
1340
    {
1341
        $this->assertSqlGeneration(
1342
            "SELECT CASE g.name WHEN 'admin' THEN - 1 ELSE - 2 END FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1343
            "SELECT CASE c0_.name WHEN 'admin' THEN -1 ELSE -2 END AS sclr_0 FROM cms_groups c0_"
1344
        );
1345
1346
        $this->assertSqlGeneration(
1347
            "SELECT CASE g.name WHEN 'admin' THEN  - 2 WHEN 'guest' THEN - 1 ELSE 0 END FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1348
            "SELECT CASE c0_.name WHEN 'admin' THEN -2 WHEN 'guest' THEN -1 ELSE 0 END AS sclr_0 FROM cms_groups c0_"
1349
        );
1350
1351
        $this->assertSqlGeneration(
1352
            "SELECT CASE g.name WHEN 'admin' THEN (- 1) ELSE (- 2) END FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1353
            "SELECT CASE c0_.name WHEN 'admin' THEN (-1) ELSE (-2) END AS sclr_0 FROM cms_groups c0_"
1354
        );
1355
1356
        $this->assertSqlGeneration(
1357
            "SELECT CASE g.name WHEN 'admin' THEN ( - :value) ELSE ( + :value) END FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1358
            "SELECT CASE c0_.name WHEN 'admin' THEN (-?) ELSE (+?) END AS sclr_0 FROM cms_groups c0_"
1359
        );
1360
1361
        $this->assertSqlGeneration(
1362
            "SELECT CASE g.name WHEN 'admin' THEN ( - g.id) ELSE ( + g.id) END FROM Doctrine\Tests\Models\CMS\CmsGroup g",
1363
            "SELECT CASE c0_.name WHEN 'admin' THEN (-c0_.id) ELSE (+c0_.id) END AS sclr_0 FROM cms_groups c0_"
1364
        );
1365
    }
1366
1367
    public function testIdentityFunctionWithCompositePrimaryKey()
1368
    {
1369
        $this->assertSqlGeneration(
1370
            "SELECT IDENTITY(p.poi, 'long') AS long FROM Doctrine\Tests\Models\Navigation\NavPhotos p",
1371
            "SELECT n0_.poi_long AS sclr_0 FROM navigation_photos n0_"
1372
        );
1373
1374
        $this->assertSqlGeneration(
1375
            "SELECT IDENTITY(p.poi, 'lat') AS lat FROM Doctrine\Tests\Models\Navigation\NavPhotos p",
1376
            "SELECT n0_.poi_lat AS sclr_0 FROM navigation_photos n0_"
1377
        );
1378
1379
        $this->assertSqlGeneration(
1380
            "SELECT IDENTITY(p.poi, 'long') AS long, IDENTITY(p.poi, 'lat') AS lat FROM Doctrine\Tests\Models\Navigation\NavPhotos p",
1381
            "SELECT n0_.poi_long AS sclr_0, n0_.poi_lat AS sclr_1 FROM navigation_photos n0_"
1382
        );
1383
1384
        $this->assertInvalidSqlGeneration(
1385
            "SELECT IDENTITY(p.poi, 'invalid') AS invalid FROM Doctrine\Tests\Models\Navigation\NavPhotos p",
1386
            QueryException::class
1387
        );
1388
    }
1389
1390
    /**
1391
     * @group DDC-2519
1392
     */
1393
    public function testPartialWithAssociationIdentifier()
1394
    {
1395
        $this->assertSqlGeneration(
1396
            "SELECT PARTIAL l.{_source, _target} FROM Doctrine\Tests\Models\Legacy\LegacyUserReference l",
1397
            'SELECT l0_.iUserIdSource AS iUserIdSource_0, l0_.iUserIdTarget AS iUserIdTarget_1 FROM legacy_users_reference l0_'
1398
        );
1399
1400
        $this->assertSqlGeneration(
1401
            "SELECT PARTIAL l.{_description, _source, _target} FROM Doctrine\Tests\Models\Legacy\LegacyUserReference l",
1402
            'SELECT l0_.description AS description_0, l0_.iUserIdSource AS iUserIdSource_1, l0_.iUserIdTarget AS iUserIdTarget_2 FROM legacy_users_reference l0_'
1403
        );
1404
    }
1405
1406
    /**
1407
     * @group DDC-1339
1408
     */
1409
    public function testIdentityFunctionInSelectClause()
1410
    {
1411
        $this->assertSqlGeneration(
1412
            "SELECT IDENTITY(u.email) as email_id FROM Doctrine\Tests\Models\CMS\CmsUser u",
1413
            "SELECT c0_.email_id AS sclr_0 FROM cms_users c0_"
1414
        );
1415
    }
1416
1417
    public function testIdentityFunctionInJoinedSubclass()
1418
    {
1419
        //relation is in the subclass (CompanyManager) we are querying
1420
        $this->assertSqlGeneration(
1421
            'SELECT m, IDENTITY(m.car) as car_id FROM Doctrine\Tests\Models\Company\CompanyManager m',
1422
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c2_.title AS title_5, c2_.car_id AS sclr_6, c0_.discr AS discr_7 FROM company_managers c2_ INNER JOIN company_employees c1_ ON c2_.id = c1_.id INNER JOIN company_persons c0_ ON c2_.id = c0_.id'
1423
        );
1424
1425
        //relation is in the base class (CompanyPerson).
1426
        $this->assertSqlGeneration(
1427
            'SELECT m, IDENTITY(m.spouse) as spouse_id FROM Doctrine\Tests\Models\Company\CompanyManager m',
1428
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c2_.title AS title_5, c0_.spouse_id AS sclr_6, c0_.discr AS discr_7 FROM company_managers c2_ INNER JOIN company_employees c1_ ON c2_.id = c1_.id INNER JOIN company_persons c0_ ON c2_.id = c0_.id'
1429
        );
1430
    }
1431
1432
    /**
1433
     * @group DDC-1339
1434
     */
1435
    public function testIdentityFunctionDoesNotAcceptStateField()
1436
    {
1437
        $this->assertInvalidSqlGeneration(
1438
            "SELECT IDENTITY(u.name) as name FROM Doctrine\Tests\Models\CMS\CmsUser u",
1439
            QueryException::class
1440
        );
1441
    }
1442
1443
    /**
1444
     * @group DDC-1389
1445
     */
1446
    public function testInheritanceTypeJoinInRootClassWithDisabledForcePartialLoad()
1447
    {
1448
        $this->assertSqlGeneration(
1449
            'SELECT p FROM Doctrine\Tests\Models\Company\CompanyPerson p',
1450
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.title AS title_2, c2_.salary AS salary_3, c2_.department AS department_4, c2_.startDate AS startDate_5, c0_.discr AS discr_6, c0_.spouse_id AS spouse_id_7, c1_.car_id AS car_id_8 FROM company_persons c0_ LEFT JOIN company_managers c1_ ON c0_.id = c1_.id LEFT JOIN company_employees c2_ ON c0_.id = c2_.id',
1451
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
1452
        );
1453
    }
1454
1455
    /**
1456
     * @group DDC-1389
1457
     */
1458
    public function testInheritanceTypeJoinInRootClassWithEnabledForcePartialLoad()
1459
    {
1460
        $this->assertSqlGeneration(
1461
            'SELECT p FROM Doctrine\Tests\Models\Company\CompanyPerson p',
1462
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c0_.discr AS discr_2 FROM company_persons c0_',
1463
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => true]
1464
        );
1465
    }
1466
1467
    /**
1468
     * @group DDC-1389
1469
     */
1470
    public function testInheritanceTypeJoinInChildClassWithDisabledForcePartialLoad()
1471
    {
1472
        $this->assertSqlGeneration(
1473
            'SELECT e FROM Doctrine\Tests\Models\Company\CompanyEmployee e',
1474
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c2_.title AS title_5, c0_.discr AS discr_6, c0_.spouse_id AS spouse_id_7, c2_.car_id AS car_id_8 FROM company_employees c1_ INNER JOIN company_persons c0_ ON c1_.id = c0_.id LEFT JOIN company_managers c2_ ON c1_.id = c2_.id',
1475
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
1476
        );
1477
    }
1478
1479
    /**
1480
     * @group DDC-1389
1481
     */
1482
    public function testInheritanceTypeJoinInChildClassWithEnabledForcePartialLoad()
1483
    {
1484
        $this->assertSqlGeneration(
1485
            'SELECT e FROM Doctrine\Tests\Models\Company\CompanyEmployee e',
1486
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c0_.discr AS discr_5 FROM company_employees c1_ INNER JOIN company_persons c0_ ON c1_.id = c0_.id',
1487
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => true]
1488
        );
1489
    }
1490
1491
    /**
1492
     * @group DDC-1389
1493
     */
1494
    public function testInheritanceTypeJoinInLeafClassWithDisabledForcePartialLoad()
1495
    {
1496
        $this->assertSqlGeneration(
1497
            'SELECT m FROM Doctrine\Tests\Models\Company\CompanyManager m',
1498
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c2_.title AS title_5, c0_.discr AS discr_6, c0_.spouse_id AS spouse_id_7, c2_.car_id AS car_id_8 FROM company_managers c2_ INNER JOIN company_employees c1_ ON c2_.id = c1_.id INNER JOIN company_persons c0_ ON c2_.id = c0_.id',
1499
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
1500
        );
1501
    }
1502
1503
    /**
1504
     * @group DDC-1389
1505
     */
1506
    public function testInheritanceTypeJoinInLeafClassWithEnabledForcePartialLoad()
1507
    {
1508
        $this->assertSqlGeneration(
1509
            'SELECT m FROM Doctrine\Tests\Models\Company\CompanyManager m',
1510
            'SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, c2_.title AS title_5, c0_.discr AS discr_6 FROM company_managers c2_ INNER JOIN company_employees c1_ ON c2_.id = c1_.id INNER JOIN company_persons c0_ ON c2_.id = c0_.id',
1511
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => true]
1512
        );
1513
    }
1514
1515
    /**
1516
     * @group DDC-1389
1517
     */
1518
    public function testInheritanceTypeSingleTableInRootClassWithDisabledForcePartialLoad()
1519
    {
1520
        $this->assertSqlGeneration(
1521
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyContract c',
1522
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6, c0_.salesPerson_id AS salesPerson_id_7 FROM company_contracts c0_ WHERE c0_.discr IN ('fix', 'flexible', 'flexultra')",
1523
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
1524
        );
1525
    }
1526
1527
    /**
1528
     * @group DDC-1389
1529
     */
1530
    public function testInheritanceTypeSingleTableInRootClassWithEnabledForcePartialLoad()
1531
    {
1532
        $this->assertSqlGeneration(
1533
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyContract c',
1534
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6 FROM company_contracts c0_ WHERE c0_.discr IN ('fix', 'flexible', 'flexultra')",
1535
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => true]
1536
        );
1537
    }
1538
1539
    /**
1540
     * @group DDC-1389
1541
     */
1542
    public function testInheritanceTypeSingleTableInChildClassWithDisabledForcePartialLoad()
1543
    {
1544
        $this->assertSqlGeneration(
1545
            'SELECT fc FROM Doctrine\Tests\Models\Company\CompanyFlexContract fc',
1546
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.hoursWorked AS hoursWorked_2, c0_.pricePerHour AS pricePerHour_3, c0_.maxPrice AS maxPrice_4, c0_.discr AS discr_5, c0_.salesPerson_id AS salesPerson_id_6 FROM company_contracts c0_ WHERE c0_.discr IN ('flexible', 'flexultra')",
1547
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
1548
        );
1549
    }
1550
1551
    /**
1552
     * @group DDC-1389
1553
     */
1554
    public function testInheritanceTypeSingleTableInChildClassWithEnabledForcePartialLoad()
1555
    {
1556
        $this->assertSqlGeneration(
1557
            'SELECT fc FROM Doctrine\Tests\Models\Company\CompanyFlexContract fc',
1558
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.hoursWorked AS hoursWorked_2, c0_.pricePerHour AS pricePerHour_3, c0_.maxPrice AS maxPrice_4, c0_.discr AS discr_5 FROM company_contracts c0_ WHERE c0_.discr IN ('flexible', 'flexultra')",
1559
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => true]
1560
        );
1561
    }
1562
1563
    /**
1564
     * @group DDC-1389
1565
     */
1566
    public function testInheritanceTypeSingleTableInLeafClassWithDisabledForcePartialLoad()
1567
    {
1568
        $this->assertSqlGeneration(
1569
            'SELECT fuc FROM Doctrine\Tests\Models\Company\CompanyFlexUltraContract fuc',
1570
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.hoursWorked AS hoursWorked_2, c0_.pricePerHour AS pricePerHour_3, c0_.maxPrice AS maxPrice_4, c0_.discr AS discr_5, c0_.salesPerson_id AS salesPerson_id_6 FROM company_contracts c0_ WHERE c0_.discr IN ('flexultra')",
1571
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
1572
        );
1573
    }
1574
1575
    /**
1576
     * @group DDC-1389
1577
     */
1578
    public function testInheritanceTypeSingleTableInLeafClassWithEnabledForcePartialLoad()
1579
    {
1580
        $this->assertSqlGeneration(
1581
            'SELECT fuc FROM Doctrine\Tests\Models\Company\CompanyFlexUltraContract fuc',
1582
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.hoursWorked AS hoursWorked_2, c0_.pricePerHour AS pricePerHour_3, c0_.maxPrice AS maxPrice_4, c0_.discr AS discr_5 FROM company_contracts c0_ WHERE c0_.discr IN ('flexultra')",
1583
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => true]
1584
        );
1585
    }
1586
1587
    /**
1588
     * @group DDC-1161
1589
     */
1590
    public function testSelfReferenceWithOneToOneDoesNotDuplicateAlias()
1591
    {
1592
        $this->assertSqlGeneration(
1593
            'SELECT p, pp FROM Doctrine\Tests\Models\Company\CompanyPerson p JOIN p.spouse pp',
1594
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.title AS title_2, c2_.salary AS salary_3, c2_.department AS department_4, c2_.startDate AS startDate_5, c3_.id AS id_6, c3_.name AS name_7, c4_.title AS title_8, c5_.salary AS salary_9, c5_.department AS department_10, c5_.startDate AS startDate_11, c0_.discr AS discr_12, c0_.spouse_id AS spouse_id_13, c1_.car_id AS car_id_14, c3_.discr AS discr_15, c3_.spouse_id AS spouse_id_16, c4_.car_id AS car_id_17 FROM company_persons c0_ LEFT JOIN company_managers c1_ ON c0_.id = c1_.id LEFT JOIN company_employees c2_ ON c0_.id = c2_.id INNER JOIN company_persons c3_ ON c0_.spouse_id = c3_.id LEFT JOIN company_managers c4_ ON c3_.id = c4_.id LEFT JOIN company_employees c5_ ON c3_.id = c5_.id",
1595
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
1596
        );
1597
    }
1598
1599
    /**
1600
     * @group DDC-1384
1601
     */
1602
    public function testAliasDoesNotExceedPlatformDefinedLength()
1603
    {
1604
        $this->assertSqlGeneration(
1605
            'SELECT m FROM ' . __NAMESPACE__ .  '\\DDC1384Model m',
1606
            "SELECT d0_.aVeryLongIdentifierThatShouldBeShortenedByTheSQLWalker_fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo AS ooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo_0 FROM DDC1384Model d0_"
1607
        );
1608
    }
1609
1610
    /**
1611
     * @group DDC-331
1612
     * @group DDC-1384
1613
     */
1614
    public function testIssue331()
1615
    {
1616
        $this->assertSqlGeneration(
1617
            'SELECT e.name FROM Doctrine\Tests\Models\Company\CompanyEmployee e',
1618
            'SELECT c0_.name AS name_0 FROM company_employees c1_ INNER JOIN company_persons c0_ ON c1_.id = c0_.id'
1619
        );
1620
    }
1621
    /**
1622
     * @group DDC-1435
1623
     */
1624
    public function testForeignKeyAsPrimaryKeySubselect()
1625
    {
1626
        $this->assertSqlGeneration(
1627
            "SELECT s FROM Doctrine\Tests\Models\DDC117\DDC117Article s WHERE EXISTS (SELECT r FROM Doctrine\Tests\Models\DDC117\DDC117Reference r WHERE r.source = s)",
1628
            "SELECT d0_.article_id AS article_id_0, d0_.title AS title_1 FROM DDC117Article d0_ WHERE EXISTS (SELECT d1_.source_id, d1_.target_id FROM DDC117Reference d1_ WHERE d1_.source_id = d0_.article_id)"
1629
        );
1630
    }
1631
1632
    /**
1633
     * @group DDC-1474
1634
     */
1635
    public function testSelectWithArithmeticExpressionBeforeField()
1636
    {
1637
        $this->assertSqlGeneration(
1638
            'SELECT - e.value AS value, e.id FROM ' . __NAMESPACE__ . '\DDC1474Entity e',
1639
            'SELECT -d0_.value AS sclr_0, d0_.id AS id_1 FROM DDC1474Entity d0_'
1640
        );
1641
1642
        $this->assertSqlGeneration(
1643
            'SELECT e.id, + e.value AS value FROM ' . __NAMESPACE__ . '\DDC1474Entity e',
1644
            'SELECT d0_.id AS id_0, +d0_.value AS sclr_1 FROM DDC1474Entity d0_'
1645
        );
1646
    }
1647
1648
     /**
1649
     * @group DDC-1430
1650
     */
1651
    public function testGroupByAllFieldsWhenObjectHasForeignKeys()
1652
    {
1653
        $this->assertSqlGeneration(
1654
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u GROUP BY u',
1655
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ GROUP BY c0_.id, c0_.status, c0_.username, c0_.name, c0_.email_id'
1656
        );
1657
1658
        $this->assertSqlGeneration(
1659
            'SELECT e FROM Doctrine\Tests\Models\CMS\CmsEmployee e GROUP BY e',
1660
            'SELECT c0_.id AS id_0, c0_.name AS name_1 FROM cms_employees c0_ GROUP BY c0_.id, c0_.name, c0_.spouse_id'
1661
        );
1662
    }
1663
1664
    /**
1665
     * @group DDC-1236
1666
     */
1667
    public function testGroupBySupportsResultVariable()
1668
    {
1669
        $this->assertSqlGeneration(
1670
            'SELECT u, u.status AS st FROM Doctrine\Tests\Models\CMS\CmsUser u GROUP BY st',
1671
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, c0_.status AS status_4 FROM cms_users c0_ GROUP BY c0_.status'
1672
        );
1673
    }
1674
1675
    /**
1676
     * @group DDC-1236
1677
     */
1678
    public function testGroupBySupportsIdentificationVariable()
1679
    {
1680
        $this->assertSqlGeneration(
1681
            'SELECT u AS user FROM Doctrine\Tests\Models\CMS\CmsUser u GROUP BY user',
1682
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ GROUP BY id_0, status_1, username_2, name_3'
1683
        );
1684
    }
1685
1686
    /**
1687
     * @group DDC-1213
1688
     */
1689
    public function testSupportsBitComparison()
1690
    {
1691
        $this->assertSqlGeneration(
1692
            'SELECT BIT_OR(4,2), BIT_AND(4,2), u FROM Doctrine\Tests\Models\CMS\CmsUser u',
1693
            'SELECT (4 | 2) AS sclr_0, (4 & 2) AS sclr_1, c0_.id AS id_2, c0_.status AS status_3, c0_.username AS username_4, c0_.name AS name_5 FROM cms_users c0_'
1694
        );
1695
        $this->assertSqlGeneration(
1696
            'SELECT BIT_OR(u.id,2), BIT_AND(u.id,2) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE BIT_OR(u.id,2) > 0',
1697
            'SELECT (c0_.id | 2) AS sclr_0, (c0_.id & 2) AS sclr_1 FROM cms_users c0_ WHERE (c0_.id | 2) > 0'
1698
        );
1699
        $this->assertSqlGeneration(
1700
            'SELECT BIT_OR(u.id,2), BIT_AND(u.id,2) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE BIT_AND(u.id , 4) > 0',
1701
            'SELECT (c0_.id | 2) AS sclr_0, (c0_.id & 2) AS sclr_1 FROM cms_users c0_ WHERE (c0_.id & 4) > 0'
1702
        );
1703
        $this->assertSqlGeneration(
1704
            'SELECT BIT_OR(u.id,2), BIT_AND(u.id,2) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE BIT_OR(u.id , 2) > 0 OR BIT_AND(u.id , 4) > 0',
1705
            'SELECT (c0_.id | 2) AS sclr_0, (c0_.id & 2) AS sclr_1 FROM cms_users c0_ WHERE (c0_.id | 2) > 0 OR (c0_.id & 4) > 0'
1706
        );
1707
    }
1708
1709
    /**
1710
     * @group DDC-1539
1711
     */
1712
    public function testParenthesesOnTheLeftHandOfComparison()
1713
    {
1714
        $this->assertSqlGeneration(
1715
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u where ( (u.id + u.id) * u.id ) > 100',
1716
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE ((c0_.id + c0_.id) * c0_.id) > 100'
1717
        );
1718
        $this->assertSqlGeneration(
1719
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u where (u.id + u.id) * u.id > 100',
1720
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE (c0_.id + c0_.id) * c0_.id > 100'
1721
        );
1722
        $this->assertSqlGeneration(
1723
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u where 100 < (u.id + u.id) * u.id ',
1724
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE 100 < (c0_.id + c0_.id) * c0_.id'
1725
        );
1726
    }
1727
1728
    public function testSupportsParenthesisExpressionInSubSelect() {
1729
        $this->assertSqlGeneration(
1730
            'SELECT u.id, (SELECT (1000*SUM(subU.id)/SUM(subU.id)) FROM Doctrine\Tests\Models\CMS\CmsUser subU where subU.id = u.id) AS subSelect FROM Doctrine\Tests\Models\CMS\CmsUser u',
1731
            'SELECT c0_.id AS id_0, (SELECT (1000 * SUM(c1_.id) / SUM(c1_.id)) FROM cms_users c1_ WHERE c1_.id = c0_.id) AS sclr_1 FROM cms_users c0_'
1732
        );
1733
    }
1734
1735
    /**
1736
     * @group DDC-1557
1737
     */
1738
    public function testSupportsSubSqlFunction()
1739
    {
1740
        $this->assertSqlGeneration(
1741
            'SELECT u1 FROM Doctrine\Tests\Models\CMS\CmsUser u1 WHERE u1.name IN ( SELECT TRIM(u2.name) FROM Doctrine\Tests\Models\CMS\CmsUser u2 )',
1742
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.name IN (SELECT TRIM(c1_.name) AS sclr_4 FROM cms_users c1_)'
1743
        );
1744
        $this->assertSqlGeneration(
1745
            'SELECT u1 FROM Doctrine\Tests\Models\CMS\CmsUser u1 WHERE u1.name IN ( SELECT TRIM(u2.name) FROM Doctrine\Tests\Models\CMS\CmsUser u2  WHERE LOWER(u2.name) LIKE \'%fabio%\')',
1746
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.name IN (SELECT TRIM(c1_.name) AS sclr_4 FROM cms_users c1_ WHERE LOWER(c1_.name) LIKE \'%fabio%\')'
1747
        );
1748
        $this->assertSqlGeneration(
1749
            'SELECT u1 FROM Doctrine\Tests\Models\CMS\CmsUser u1 WHERE u1.email IN ( SELECT TRIM(IDENTITY(u2.email)) FROM Doctrine\Tests\Models\CMS\CmsUser u2 )',
1750
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.email_id IN (SELECT TRIM(c1_.email_id) AS sclr_4 FROM cms_users c1_)'
1751
        );
1752
        $this->assertSqlGeneration(
1753
            'SELECT u1 FROM Doctrine\Tests\Models\CMS\CmsUser u1 WHERE u1.email IN ( SELECT IDENTITY(u2.email) FROM Doctrine\Tests\Models\CMS\CmsUser u2 )',
1754
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.email_id IN (SELECT c1_.email_id AS sclr_4 FROM cms_users c1_)'
1755
        );
1756
        $this->assertSqlGeneration(
1757
            'SELECT u1 FROM Doctrine\Tests\Models\CMS\CmsUser u1 WHERE COUNT(u1.id) = ( SELECT SUM(u2.id) FROM Doctrine\Tests\Models\CMS\CmsUser u2 )',
1758
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE COUNT(c0_.id) = (SELECT SUM(c1_.id) AS sclr_4 FROM cms_users c1_)'
1759
        );
1760
        $this->assertSqlGeneration(
1761
            'SELECT u1 FROM Doctrine\Tests\Models\CMS\CmsUser u1 WHERE COUNT(u1.id) <= ( SELECT SUM(u2.id) + COUNT(u2.email) FROM Doctrine\Tests\Models\CMS\CmsUser u2 )',
1762
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE COUNT(c0_.id) <= (SELECT SUM(c1_.id) + COUNT(c1_.email_id) AS sclr_4 FROM cms_users c1_)'
1763
        );
1764
    }
1765
1766
    /**
1767
     * @group DDC-1574
1768
     */
1769
    public function testSupportsNewOperator()
1770
    {
1771
        $this->assertSqlGeneration(
1772
            "SELECT new Doctrine\Tests\Models\CMS\CmsUserDTO(u.name, e.email, a.city) FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.email e JOIN u.address a",
1773
            "SELECT c0_.name AS sclr_0, c1_.email AS sclr_1, c2_.city AS sclr_2 FROM cms_users c0_ INNER JOIN cms_emails c1_ ON c0_.email_id = c1_.id INNER JOIN cms_addresses c2_ ON c0_.id = c2_.user_id"
1774
        );
1775
1776
        $this->assertSqlGeneration(
1777
            "SELECT new Doctrine\Tests\Models\CMS\CmsUserDTO(u.name, e.email, a.id + u.id) FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.email e JOIN u.address a",
1778
            "SELECT c0_.name AS sclr_0, c1_.email AS sclr_1, c2_.id + c0_.id AS sclr_2 FROM cms_users c0_ INNER JOIN cms_emails c1_ ON c0_.email_id = c1_.id INNER JOIN cms_addresses c2_ ON c0_.id = c2_.user_id"
1779
        );
1780
1781
        $this->assertSqlGeneration(
1782
            "SELECT new Doctrine\Tests\Models\CMS\CmsUserDTO(u.name, e.email, a.city, COUNT(p)) FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.email e JOIN u.address a JOIN u.phonenumbers p",
1783
            "SELECT c0_.name AS sclr_0, c1_.email AS sclr_1, c2_.city AS sclr_2, COUNT(c3_.phonenumber) AS sclr_3 FROM cms_users c0_ INNER JOIN cms_emails c1_ ON c0_.email_id = c1_.id INNER JOIN cms_addresses c2_ ON c0_.id = c2_.user_id INNER JOIN cms_phonenumbers c3_ ON c0_.id = c3_.user_id"
1784
        );
1785
1786
        $this->assertSqlGeneration(
1787
            "SELECT new Doctrine\Tests\Models\CMS\CmsUserDTO(u.name, e.email, a.city, COUNT(p) + u.id) FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.email e JOIN u.address a JOIN u.phonenumbers p",
1788
            "SELECT c0_.name AS sclr_0, c1_.email AS sclr_1, c2_.city AS sclr_2, COUNT(c3_.phonenumber) + c0_.id AS sclr_3 FROM cms_users c0_ INNER JOIN cms_emails c1_ ON c0_.email_id = c1_.id INNER JOIN cms_addresses c2_ ON c0_.id = c2_.user_id INNER JOIN cms_phonenumbers c3_ ON c0_.id = c3_.user_id"
1789
        );
1790
1791
        $this->assertSqlGeneration(
1792
            "SELECT new Doctrine\Tests\Models\CMS\CmsUserDTO(a.id, a.country, a.city), new Doctrine\Tests\Models\CMS\CmsAddressDTO(u.name, e.email) FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.email e JOIN u.address a ORDER BY u.name",
1793
            "SELECT c0_.id AS sclr_0, c0_.country AS sclr_1, c0_.city AS sclr_2, c1_.name AS sclr_3, c2_.email AS sclr_4 FROM cms_users c1_ INNER JOIN cms_emails c2_ ON c1_.email_id = c2_.id INNER JOIN cms_addresses c0_ ON c1_.id = c0_.user_id ORDER BY c1_.name ASC"
1794
        );
1795
1796
        $this->assertSqlGeneration(
1797
            "SELECT new Doctrine\Tests\Models\CMS\CmsUserDTO(a.id, (SELECT 1 FROM Doctrine\Tests\Models\CMS\CmsUser su), a.country, a.city), new Doctrine\Tests\Models\CMS\CmsAddressDTO(u.name, e.email) FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.email e JOIN u.address a ORDER BY u.name",
1798
            "SELECT c0_.id AS sclr_0, (SELECT 1 AS sclr_2 FROM cms_users c1_) AS sclr_1, c0_.country AS sclr_3, c0_.city AS sclr_4, c2_.name AS sclr_5, c3_.email AS sclr_6 FROM cms_users c2_ INNER JOIN cms_emails c3_ ON c2_.email_id = c3_.id INNER JOIN cms_addresses c0_ ON c2_.id = c0_.user_id ORDER BY c2_.name ASC"
1799
        );
1800
    }
1801
1802
    /**
1803
     * @group DDC-2234
1804
     */
1805
    public function testWhereFunctionIsNullComparisonExpression()
1806
    {
1807
        $this->assertSqlGeneration(
1808
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE IDENTITY(u.email) IS NULL",
1809
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.email_id IS NULL"
1810
        );
1811
1812
        $this->assertSqlGeneration(
1813
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE NULLIF(u.name, 'FabioBatSilva') IS NULL AND IDENTITY(u.email) IS NOT NULL",
1814
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE NULLIF(c0_.name, 'FabioBatSilva') IS NULL AND c0_.email_id IS NOT NULL"
1815
        );
1816
1817
        $this->assertSqlGeneration(
1818
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE IDENTITY(u.email) IS NOT NULL",
1819
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE c0_.email_id IS NOT NULL"
1820
        );
1821
1822
        $this->assertSqlGeneration(
1823
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE NULLIF(u.name, 'FabioBatSilva') IS NOT NULL",
1824
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE NULLIF(c0_.name, 'FabioBatSilva') IS NOT NULL"
1825
        );
1826
1827
        $this->assertSqlGeneration(
1828
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE COALESCE(u.name, u.id) IS NOT NULL",
1829
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE COALESCE(c0_.name, c0_.id) IS NOT NULL"
1830
        );
1831
1832
        $this->assertSqlGeneration(
1833
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE COALESCE(u.id, IDENTITY(u.email)) IS NOT NULL",
1834
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE COALESCE(c0_.id, c0_.email_id) IS NOT NULL"
1835
        );
1836
1837
        $this->assertSqlGeneration(
1838
            "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE COALESCE(IDENTITY(u.email), NULLIF(u.name, 'FabioBatSilva')) IS NOT NULL",
1839
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ WHERE COALESCE(c0_.email_id, NULLIF(c0_.name, 'FabioBatSilva')) IS NOT NULL"
1840
        );
1841
    }
1842
1843
    public function testCustomTypeValueSql()
1844
    {
1845
        if (DBALType::hasType('negative_to_positive')) {
1846
            DBALType::overrideType('negative_to_positive', NegativeToPositiveType::class);
1847
        } else {
1848
            DBALType::addType('negative_to_positive', NegativeToPositiveType::class);
1849
        }
1850
1851
        $this->assertSqlGeneration(
1852
            'SELECT p.customInteger FROM Doctrine\Tests\Models\CustomType\CustomTypeParent p WHERE p.id = 1',
1853
            'SELECT -(c0_.customInteger) AS customInteger_0 FROM customtype_parents c0_ WHERE c0_.id = 1'
1854
        );
1855
    }
1856
1857
    public function testCustomTypeValueSqlIgnoresIdentifierColumn()
1858
    {
1859
        if (DBALType::hasType('negative_to_positive')) {
1860
            DBALType::overrideType('negative_to_positive', NegativeToPositiveType::class);
1861
        } else {
1862
            DBALType::addType('negative_to_positive', NegativeToPositiveType::class);
1863
        }
1864
1865
        $this->assertSqlGeneration(
1866
            'SELECT p.id FROM Doctrine\Tests\Models\CustomType\CustomTypeParent p WHERE p.id = 1',
1867
            'SELECT c0_.id AS id_0 FROM customtype_parents c0_ WHERE c0_.id = 1'
1868
        );
1869
    }
1870
1871
    public function testCustomTypeValueSqlForAllFields()
1872
    {
1873
        if (DBALType::hasType('negative_to_positive')) {
1874
            DBALType::overrideType('negative_to_positive', NegativeToPositiveType::class);
1875
        } else {
1876
            DBALType::addType('negative_to_positive', NegativeToPositiveType::class);
1877
        }
1878
1879
        $this->assertSqlGeneration(
1880
            'SELECT p FROM Doctrine\Tests\Models\CustomType\CustomTypeParent p',
1881
            'SELECT c0_.id AS id_0, -(c0_.customInteger) AS customInteger_1 FROM customtype_parents c0_'
1882
        );
1883
    }
1884
1885
    public function testCustomTypeValueSqlForPartialObject()
1886
    {
1887
        if (DBALType::hasType('negative_to_positive')) {
1888
            DBALType::overrideType('negative_to_positive', NegativeToPositiveType::class);
1889
        } else {
1890
            DBALType::addType('negative_to_positive', NegativeToPositiveType::class);
1891
        }
1892
1893
        $this->assertSqlGeneration(
1894
            'SELECT partial p.{id, customInteger} FROM Doctrine\Tests\Models\CustomType\CustomTypeParent p',
1895
            'SELECT c0_.id AS id_0, -(c0_.customInteger) AS customInteger_1 FROM customtype_parents c0_'
1896
        );
1897
    }
1898
1899
    /**
1900
     * @group DDC-1529
1901
     */
1902
    public function testMultipleFromAndInheritanceCondition()
1903
    {
1904
        $this->assertSqlGeneration(
1905
            'SELECT fix, flex FROM Doctrine\Tests\Models\Company\CompanyFixContract fix, Doctrine\Tests\Models\Company\CompanyFlexContract flex',
1906
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c1_.id AS id_3, c1_.completed AS completed_4, c1_.hoursWorked AS hoursWorked_5, c1_.pricePerHour AS pricePerHour_6, c1_.maxPrice AS maxPrice_7, c0_.discr AS discr_8, c1_.discr AS discr_9 FROM company_contracts c0_, company_contracts c1_ WHERE (c0_.discr IN ('fix') AND c1_.discr IN ('flexible', 'flexultra'))"
1907
        );
1908
    }
1909
1910
    /**
1911
     * @group DDC-775
1912
     */
1913
    public function testOrderByClauseSupportsSimpleArithmeticExpression()
1914
    {
1915
        $this->assertSqlGeneration(
1916
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u ORDER BY u.id + 1 ',
1917
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ ORDER BY c0_.id + 1 ASC'
1918
        );
1919
        $this->assertSqlGeneration(
1920
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u ORDER BY ( ( (u.id + 1) * (u.id - 1) ) / 2)',
1921
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ ORDER BY (((c0_.id + 1) * (c0_.id - 1)) / 2) ASC'
1922
        );
1923
        $this->assertSqlGeneration(
1924
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u ORDER BY ((u.id + 5000) * u.id + 3) ',
1925
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ ORDER BY ((c0_.id + 5000) * c0_.id + 3) ASC'
1926
        );
1927
    }
1928
1929
    public function testOrderByClauseSupportsFunction()
1930
    {
1931
        $this->assertSqlGeneration(
1932
            'SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u ORDER BY CONCAT(u.username, u.name) ',
1933
            'SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3 FROM cms_users c0_ ORDER BY c0_.username || c0_.name ASC'
1934
        );
1935
    }
1936
1937
    /**
1938
     * @group DDC-1719
1939
     */
1940
    public function testStripNonAlphanumericCharactersFromAlias()
1941
    {
1942
        $this->assertSqlGeneration(
1943
            'SELECT e FROM Doctrine\Tests\Models\Generic\NonAlphaColumnsEntity e',
1944
            'SELECT n0_."simple-entity-id" AS simpleentityid_0, n0_."simple-entity-value" AS simpleentityvalue_1 FROM "not-a-simple-entity" n0_'
1945
        );
1946
1947
        $this->assertSqlGeneration(
1948
            'SELECT e.value FROM Doctrine\Tests\Models\Generic\NonAlphaColumnsEntity e ORDER BY e.value',
1949
            'SELECT n0_."simple-entity-value" AS simpleentityvalue_0 FROM "not-a-simple-entity" n0_ ORDER BY n0_."simple-entity-value" ASC'
1950
        );
1951
1952
        $this->assertSqlGeneration(
1953
            'SELECT TRIM(e.value) FROM Doctrine\Tests\Models\Generic\NonAlphaColumnsEntity e ORDER BY e.value',
1954
            'SELECT TRIM(n0_."simple-entity-value") AS sclr_0 FROM "not-a-simple-entity" n0_ ORDER BY n0_."simple-entity-value" ASC'
1955
        );
1956
    }
1957
1958
    /**
1959
     * @group DDC-2435
1960
     */
1961
    public function testColumnNameWithNumbersAndNonAlphanumericCharacters()
1962
    {
1963
        $this->assertSqlGeneration(
1964
            'SELECT e FROM Doctrine\Tests\Models\Quote\NumericEntity e',
1965
            'SELECT t0_."1:1" AS 11_0, t0_."2:2" AS 22_1 FROM table t0_'
1966
        );
1967
1968
        $this->assertSqlGeneration(
1969
            'SELECT e.value FROM Doctrine\Tests\Models\Quote\NumericEntity e',
1970
            'SELECT t0_."2:2" AS 22_0 FROM table t0_'
1971
        );
1972
1973
        $this->assertSqlGeneration(
1974
            'SELECT TRIM(e.value) FROM Doctrine\Tests\Models\Quote\NumericEntity e',
1975
            'SELECT TRIM(t0_."2:2") AS sclr_0 FROM table t0_'
1976
        );
1977
    }
1978
1979
    /**
1980
     * @group DDC-1845
1981
     */
1982
    public function testQuotedTableDeclaration()
1983
    {
1984
        $this->assertSqlGeneration(
1985
            'SELECT u FROM Doctrine\Tests\Models\Quote\User u',
1986
            'SELECT q0_."user-id" AS userid_0, q0_."user-name" AS username_1 FROM "quote-user" q0_'
1987
        );
1988
    }
1989
1990
   /**
1991
    * @group DDC-1845
1992
    */
1993
    public function testQuotedWalkJoinVariableDeclaration()
1994
    {
1995
        $this->assertSqlGeneration(
1996
            'SELECT u, a FROM Doctrine\Tests\Models\Quote\User u JOIN u.address a',
1997
            'SELECT q0_."user-id" AS userid_0, q0_."user-name" AS username_1, q1_."address-id" AS addressid_2, q1_."address-zip" AS addresszip_3, q1_.type AS type_4 FROM "quote-user" q0_ INNER JOIN "quote-address" q1_ ON q0_."address-id" = q1_."address-id" AND q1_.type IN (\'simple\', \'full\')'
1998
        );
1999
2000
        $this->assertSqlGeneration(
2001
            'SELECT u, p FROM Doctrine\Tests\Models\Quote\User u JOIN u.phones p',
2002
            'SELECT q0_."user-id" AS userid_0, q0_."user-name" AS username_1, q1_."phone-number" AS phonenumber_2 FROM "quote-user" q0_ INNER JOIN "quote-phone" q1_ ON q0_."user-id" = q1_."user-id"'
2003
        );
2004
2005
        $this->assertSqlGeneration(
2006
            'SELECT u, g FROM Doctrine\Tests\Models\Quote\User u JOIN u.groups g',
2007
            'SELECT q0_."user-id" AS userid_0, q0_."user-name" AS username_1, q1_."group-id" AS groupid_2, q1_."group-name" AS groupname_3 FROM "quote-user" q0_ INNER JOIN "quote-users-groups" q2_ ON q0_."user-id" = q2_."user-id" INNER JOIN "quote-group" q1_ ON q1_."group-id" = q2_."group-id"'
2008
        );
2009
2010
        $this->assertSqlGeneration(
2011
            'SELECT a, u FROM Doctrine\Tests\Models\Quote\Address a JOIN a.user u',
2012
            'SELECT q0_."address-id" AS addressid_0, q0_."address-zip" AS addresszip_1, q1_."user-id" AS userid_2, q1_."user-name" AS username_3, q0_.type AS type_4 FROM "quote-address" q0_ INNER JOIN "quote-user" q1_ ON q0_."user-id" = q1_."user-id" WHERE q0_.type IN (\'simple\', \'full\')'
2013
        );
2014
2015
        $this->assertSqlGeneration(
2016
            'SELECT g, u FROM Doctrine\Tests\Models\Quote\Group g JOIN g.users u',
2017
            'SELECT q0_."group-id" AS groupid_0, q0_."group-name" AS groupname_1, q1_."user-id" AS userid_2, q1_."user-name" AS username_3 FROM "quote-group" q0_ INNER JOIN "quote-users-groups" q2_ ON q0_."group-id" = q2_."group-id" INNER JOIN "quote-user" q1_ ON q1_."user-id" = q2_."user-id"'
2018
        );
2019
2020
        $this->assertSqlGeneration(
2021
            'SELECT g, p FROM Doctrine\Tests\Models\Quote\Group g JOIN g.parent p',
2022
            'SELECT q0_."group-id" AS groupid_0, q0_."group-name" AS groupname_1, q1_."group-id" AS groupid_2, q1_."group-name" AS groupname_3 FROM "quote-group" q0_ INNER JOIN "quote-group" q1_ ON q0_."parent-id" = q1_."group-id"'
2023
        );
2024
    }
2025
2026
   /**
2027
    * @group DDC-2208
2028
    */
2029
    public function testCaseThenParameterArithmeticExpression()
2030
    {
2031
        $this->assertSqlGeneration(
2032
            'SELECT SUM(CASE WHEN e.salary <= :value THEN e.salary - :value WHEN e.salary >= :value THEN :value - e.salary ELSE 0 END) FROM Doctrine\Tests\Models\Company\CompanyEmployee e',
2033
            'SELECT SUM(CASE WHEN c0_.salary <= ? THEN c0_.salary - ? WHEN c0_.salary >= ? THEN ? - c0_.salary ELSE 0 END) AS sclr_0 FROM company_employees c0_ INNER JOIN company_persons c1_ ON c0_.id = c1_.id'
2034
        );
2035
2036
        $this->assertSqlGeneration(
2037
            'SELECT SUM(CASE WHEN e.salary <= :value THEN e.salary - :value WHEN e.salary >= :value THEN :value - e.salary ELSE e.salary + 0 END) FROM Doctrine\Tests\Models\Company\CompanyEmployee e',
2038
            'SELECT SUM(CASE WHEN c0_.salary <= ? THEN c0_.salary - ? WHEN c0_.salary >= ? THEN ? - c0_.salary ELSE c0_.salary + 0 END) AS sclr_0 FROM company_employees c0_ INNER JOIN company_persons c1_ ON c0_.id = c1_.id'
2039
        );
2040
2041
        $this->assertSqlGeneration(
2042
            'SELECT SUM(CASE WHEN e.salary <= :value THEN (e.salary - :value) WHEN e.salary >= :value THEN (:value - e.salary) ELSE (e.salary + :value) END) FROM Doctrine\Tests\Models\Company\CompanyEmployee e',
2043
            'SELECT SUM(CASE WHEN c0_.salary <= ? THEN (c0_.salary - ?) WHEN c0_.salary >= ? THEN (? - c0_.salary) ELSE (c0_.salary + ?) END) AS sclr_0 FROM company_employees c0_ INNER JOIN company_persons c1_ ON c0_.id = c1_.id'
2044
        );
2045
    }
2046
2047
    /**
2048
    * @group DDC-2268
2049
    */
2050
    public function testCaseThenFunction()
2051
    {
2052
        $this->assertSqlGeneration(
2053
            'SELECT CASE WHEN LENGTH(u.name) <> 0 THEN CONCAT(u.id, u.name) ELSE u.id END AS name  FROM Doctrine\Tests\Models\CMS\CmsUser u',
2054
            'SELECT CASE WHEN LENGTH(c0_.name) <> 0 THEN c0_.id || c0_.name ELSE c0_.id END AS sclr_0 FROM cms_users c0_'
2055
        );
2056
2057
        $this->assertSqlGeneration(
2058
            'SELECT CASE WHEN LENGTH(u.name) <> LENGTH(TRIM(u.name)) THEN TRIM(u.name) ELSE u.name END AS name  FROM Doctrine\Tests\Models\CMS\CmsUser u',
2059
            'SELECT CASE WHEN LENGTH(c0_.name) <> LENGTH(TRIM(c0_.name)) THEN TRIM(c0_.name) ELSE c0_.name END AS sclr_0 FROM cms_users c0_'
2060
        );
2061
2062
        $this->assertSqlGeneration(
2063
            'SELECT CASE WHEN LENGTH(u.name) > :value THEN SUBSTRING(u.name, 0, :value) ELSE TRIM(u.name) END AS name  FROM Doctrine\Tests\Models\CMS\CmsUser u',
2064
            'SELECT CASE WHEN LENGTH(c0_.name) > ? THEN SUBSTRING(c0_.name FROM 0 FOR ?) ELSE TRIM(c0_.name) END AS sclr_0 FROM cms_users c0_'
2065
        );
2066
    }
2067
2068
    /**
2069
     * @group DDC-2268
2070
     */
2071
    public function testSupportsMoreThanTwoParametersInConcatFunction()
2072
    {
2073
    	$connMock    = $this->_em->getConnection();
2074
    	$orgPlatform = $connMock->getDatabasePlatform();
2075
2076
    	$connMock->setDatabasePlatform(new MySqlPlatform());
2077
    	$this->assertSqlGeneration(
2078
            "SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE CONCAT(u.name, u.status, 's') = ?1",
2079
            "SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE CONCAT(c0_.name, c0_.status, 's') = ?"
2080
    	);
2081
    	$this->assertSqlGeneration(
2082
            "SELECT CONCAT(u.id, u.name, u.status) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = ?1",
2083
            "SELECT CONCAT(c0_.id, c0_.name, c0_.status) AS sclr_0 FROM cms_users c0_ WHERE c0_.id = ?"
2084
    	);
2085
2086
    	$connMock->setDatabasePlatform(new PostgreSqlPlatform());
2087
    	$this->assertSqlGeneration(
2088
            "SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE CONCAT(u.name, u.status, 's') = ?1",
2089
            "SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE c0_.name || c0_.status || 's' = ?"
2090
    	);
2091
    	$this->assertSqlGeneration(
2092
            "SELECT CONCAT(u.id, u.name, u.status) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = ?1",
2093
            "SELECT c0_.id || c0_.name || c0_.status AS sclr_0 FROM cms_users c0_ WHERE c0_.id = ?"
2094
    	);
2095
2096
    	$connMock->setDatabasePlatform(new SQLServerPlatform());
2097
    	$this->assertSqlGeneration(
2098
            "SELECT u.id FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE CONCAT(u.name, u.status, 's') = ?1",
2099
            "SELECT c0_.id AS id_0 FROM cms_users c0_ WHERE (c0_.name + c0_.status + 's') = ?"
2100
    	);
2101
    	$this->assertSqlGeneration(
2102
            "SELECT CONCAT(u.id, u.name, u.status) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE u.id = ?1",
2103
            "SELECT (c0_.id + c0_.name + c0_.status) AS sclr_0 FROM cms_users c0_ WHERE c0_.id = ?"
2104
    	);
2105
2106
    	$connMock->setDatabasePlatform($orgPlatform);
2107
    }
2108
2109
     /**
2110
     * @group DDC-2188
2111
     */
2112
    public function testArithmeticPriority()
2113
    {
2114
        $this->assertSqlGeneration(
2115
            'SELECT 100/(2*2) FROM Doctrine\Tests\Models\CMS\CmsUser u',
2116
            'SELECT 100 / (2 * 2) AS sclr_0 FROM cms_users c0_'
2117
        );
2118
2119
        $this->assertSqlGeneration(
2120
            'SELECT (u.id / (u.id * 2)) FROM Doctrine\Tests\Models\CMS\CmsUser u',
2121
            'SELECT (c0_.id / (c0_.id * 2)) AS sclr_0 FROM cms_users c0_'
2122
        );
2123
2124
        $this->assertSqlGeneration(
2125
            'SELECT 100/(2*2) + (u.id / (u.id * 2)) FROM Doctrine\Tests\Models\CMS\CmsUser u WHERE (u.id / (u.id * 2)) > 0',
2126
            'SELECT 100 / (2 * 2) + (c0_.id / (c0_.id * 2)) AS sclr_0 FROM cms_users c0_ WHERE (c0_.id / (c0_.id * 2)) > 0'
2127
        );
2128
    }
2129
2130
    /**
2131
    * @group DDC-2475
2132
    */
2133
    public function testOrderByClauseShouldReplaceOrderByRelationMapping()
2134
    {
2135
        $this->assertSqlGeneration(
2136
            'SELECT r, b FROM Doctrine\Tests\Models\Routing\RoutingRoute r JOIN r.bookings b',
2137
            'SELECT r0_.id AS id_0, r1_.id AS id_1, r1_.passengerName AS passengerName_2 FROM RoutingRoute r0_ INNER JOIN RoutingRouteBooking r1_ ON r0_.id = r1_.route_id ORDER BY r1_.passengerName ASC'
2138
        );
2139
2140
        $this->assertSqlGeneration(
2141
            'SELECT r, b FROM Doctrine\Tests\Models\Routing\RoutingRoute r JOIN r.bookings b ORDER BY b.passengerName DESC',
2142
            'SELECT r0_.id AS id_0, r1_.id AS id_1, r1_.passengerName AS passengerName_2 FROM RoutingRoute r0_ INNER JOIN RoutingRouteBooking r1_ ON r0_.id = r1_.route_id ORDER BY r1_.passengerName DESC'
2143
        );
2144
    }
2145
2146
    /**
2147
     * @group DDC-1858
2148
     */
2149
    public function testHavingSupportIsNullExpression()
2150
    {
2151
        $this->assertSqlGeneration(
2152
            'SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u HAVING u.username IS NULL',
2153
            'SELECT c0_.name AS name_0 FROM cms_users c0_ HAVING c0_.username IS NULL'
2154
        );
2155
2156
        $this->assertSqlGeneration(
2157
            'SELECT u.name FROM Doctrine\Tests\Models\CMS\CmsUser u HAVING MAX(u.name) IS NULL',
2158
            'SELECT c0_.name AS name_0 FROM cms_users c0_ HAVING MAX(c0_.name) IS NULL'
2159
        );
2160
    }
2161
2162
    /**
2163
     * @group DDC-2506
2164
     */
2165
    public function testClassTableInheritanceJoinWithConditionAppliesToBaseTable()
2166
    {
2167
        $this->assertSqlGeneration(
2168
            'SELECT e.id FROM Doctrine\Tests\Models\Company\CompanyOrganization o JOIN o.events e WITH e.id = ?1',
2169
            'SELECT c0_.id AS id_0 FROM company_organizations c1_ INNER JOIN (company_events c0_ LEFT JOIN company_auctions c2_ ON c0_.id = c2_.id LEFT JOIN company_raffles c3_ ON c0_.id = c3_.id) ON c1_.id = c0_.org_id AND (c0_.id = ?)',
2170
            [ORMQuery::HINT_FORCE_PARTIAL_LOAD => false]
2171
        );
2172
    }
2173
2174
    /**
2175
     * @group DDC-2235
2176
     */
2177
    public function testSingleTableInheritanceLeftJoinWithCondition()
2178
    {
2179
        // Regression test for the bug
2180
        $this->assertSqlGeneration(
2181
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyEmployee e LEFT JOIN Doctrine\Tests\Models\Company\CompanyContract c WITH c.salesPerson = e.id',
2182
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6 FROM company_employees c1_ INNER JOIN company_persons c2_ ON c1_.id = c2_.id LEFT JOIN company_contracts c0_ ON (c0_.salesPerson_id = c2_.id) AND c0_.discr IN ('fix', 'flexible', 'flexultra')"
2183
        );
2184
    }
2185
2186
    /**
2187
     * @group DDC-2235
2188
     */
2189
    public function testSingleTableInheritanceLeftJoinWithConditionAndWhere()
2190
    {
2191
        // Ensure other WHERE predicates are passed through to the main WHERE clause
2192
        $this->assertSqlGeneration(
2193
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyEmployee e LEFT JOIN Doctrine\Tests\Models\Company\CompanyContract c WITH c.salesPerson = e.id WHERE e.salary > 1000',
2194
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6 FROM company_employees c1_ INNER JOIN company_persons c2_ ON c1_.id = c2_.id LEFT JOIN company_contracts c0_ ON (c0_.salesPerson_id = c2_.id) AND c0_.discr IN ('fix', 'flexible', 'flexultra') WHERE c1_.salary > 1000"
2195
        );
2196
    }
2197
2198
    /**
2199
     * @group DDC-2235
2200
     */
2201
    public function testSingleTableInheritanceInnerJoinWithCondition()
2202
    {
2203
        // Test inner joins too
2204
        $this->assertSqlGeneration(
2205
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyEmployee e INNER JOIN Doctrine\Tests\Models\Company\CompanyContract c WITH c.salesPerson = e.id',
2206
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6 FROM company_employees c1_ INNER JOIN company_persons c2_ ON c1_.id = c2_.id INNER JOIN company_contracts c0_ ON (c0_.salesPerson_id = c2_.id) AND c0_.discr IN ('fix', 'flexible', 'flexultra')"
2207
        );
2208
    }
2209
2210
    /**
2211
     * @group DDC-2235
2212
     */
2213
    public function testSingleTableInheritanceLeftJoinNonAssociationWithConditionAndWhere()
2214
    {
2215
        // Test that the discriminator IN() predicate is still added into
2216
        // the where clause when not joining onto that table
2217
        $this->assertSqlGeneration(
2218
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyContract c LEFT JOIN Doctrine\Tests\Models\Company\CompanyEmployee e WITH e.id = c.salesPerson WHERE c.completed = true',
2219
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6 FROM company_contracts c0_ LEFT JOIN (company_employees c1_ INNER JOIN company_persons c2_ ON c1_.id = c2_.id) ON (c2_.id = c0_.salesPerson_id) WHERE (c0_.completed = 1) AND c0_.discr IN ('fix', 'flexible', 'flexultra')"
2220
        );
2221
    }
2222
2223
    /**
2224
     * @group DDC-2235
2225
     */
2226
    public function testSingleTableInheritanceJoinCreatesOnCondition()
2227
    {
2228
        // Test that the discriminator IN() predicate is still added
2229
        // into the where clause when not joining onto a single table inheritance entity
2230
        // via a join association
2231
        $this->assertSqlGeneration(
2232
            'SELECT c FROM Doctrine\Tests\Models\Company\CompanyContract c JOIN c.salesPerson s WHERE c.completed = true',
2233
            "SELECT c0_.id AS id_0, c0_.completed AS completed_1, c0_.fixPrice AS fixPrice_2, c0_.hoursWorked AS hoursWorked_3, c0_.pricePerHour AS pricePerHour_4, c0_.maxPrice AS maxPrice_5, c0_.discr AS discr_6 FROM company_contracts c0_ INNER JOIN company_employees c1_ ON c0_.salesPerson_id = c1_.id LEFT JOIN company_persons c2_ ON c1_.id = c2_.id WHERE (c0_.completed = 1) AND c0_.discr IN ('fix', 'flexible', 'flexultra')"
2234
        );
2235
    }
2236
2237
    /**
2238
     * @group DDC-2235
2239
     */
2240
    public function testSingleTableInheritanceCreatesOnConditionAndWhere()
2241
    {
2242
        // Test that when joining onto an entity using single table inheritance via
2243
        // a join association that the discriminator IN() predicate is placed
2244
        // into the ON clause of the join
2245
        $this->assertSqlGeneration(
2246
            'SELECT e, COUNT(c) FROM Doctrine\Tests\Models\Company\CompanyEmployee e JOIN e.contracts c WHERE e.department = :department',
2247
            "SELECT c0_.id AS id_0, c0_.name AS name_1, c1_.salary AS salary_2, c1_.department AS department_3, c1_.startDate AS startDate_4, COUNT(c2_.id) AS sclr_5, c0_.discr AS discr_6 FROM company_employees c1_ INNER JOIN company_persons c0_ ON c1_.id = c0_.id INNER JOIN company_contract_employees c3_ ON c1_.id = c3_.employee_id INNER JOIN company_contracts c2_ ON c2_.id = c3_.contract_id AND c2_.discr IN ('fix', 'flexible', 'flexultra') WHERE c1_.department = ?",
2248
            [],
2249
            ['department' => 'foobar']
2250
        );
2251
    }
2252
2253
    /**
2254
     * @group DDC-1858
2255
     */
2256
    public function testHavingSupportResultVariableInExpression()
2257
    {
2258
        $this->assertSqlGeneration(
2259
            'SELECT u.name AS foo FROM Doctrine\Tests\Models\CMS\CmsUser u HAVING foo IN (?1)',
2260
            'SELECT c0_.name AS name_0 FROM cms_users c0_ HAVING name_0 IN (?)'
2261
        );
2262
    }
2263
2264
    /**
2265
     * @group DDC-1858
2266
     */
2267
    public function testHavingSupportResultVariableLikeExpression()
2268
    {
2269
        $this->assertSqlGeneration(
2270
            "SELECT u.name AS foo FROM Doctrine\Tests\Models\CMS\CmsUser u HAVING foo LIKE '3'",
2271
            "SELECT c0_.name AS name_0 FROM cms_users c0_ HAVING name_0 LIKE '3'"
2272
        );
2273
    }
2274
2275
    /**
2276
     * @group DDC-3085
2277
     */
2278
    public function testHavingSupportResultVariableNullComparisonExpression()
2279
    {
2280
        $this->assertSqlGeneration(
2281
            "SELECT u AS user, SUM(a.id) AS score FROM Doctrine\Tests\Models\CMS\CmsUser u LEFT JOIN Doctrine\Tests\Models\CMS\CmsAddress a WITH a.user = u GROUP BY u HAVING score IS NOT NULL AND score >= 5",
2282
            "SELECT c0_.id AS id_0, c0_.status AS status_1, c0_.username AS username_2, c0_.name AS name_3, SUM(c1_.id) AS sclr_4 FROM cms_users c0_ LEFT JOIN cms_addresses c1_ ON (c1_.user_id = c0_.id) GROUP BY c0_.id, c0_.status, c0_.username, c0_.name, c0_.email_id HAVING sclr_4 IS NOT NULL AND sclr_4 >= 5"
2283
        );
2284
    }
2285
2286
    /**
2287
     * @group DDC-1858
2288
     */
2289
    public function testHavingSupportResultVariableInAggregateFunction()
2290
    {
2291
        $this->assertSqlGeneration(
2292
            'SELECT COUNT(u.name) AS countName FROM Doctrine\Tests\Models\CMS\CmsUser u HAVING countName IS NULL',
2293
            'SELECT COUNT(c0_.name) AS sclr_0 FROM cms_users c0_ HAVING sclr_0 IS NULL'
2294
        );
2295
    }
2296
2297
    /**
2298
     * GitHub issue #4764: https://github.com/doctrine/doctrine2/issues/4764
2299
     * @group DDC-3907
2300
     * @dataProvider mathematicOperatorsProvider
2301
     */
2302
    public function testHavingRegressionUsingVariableWithMathOperatorsExpression($operator)
2303
    {
2304
        $this->assertSqlGeneration(
2305
            'SELECT COUNT(u.name) AS countName FROM Doctrine\Tests\Models\CMS\CmsUser u HAVING 1 ' . $operator . ' countName > 0',
2306
            'SELECT COUNT(c0_.name) AS sclr_0 FROM cms_users c0_ HAVING 1 ' . $operator . ' sclr_0 > 0'
2307
        );
2308
    }
2309
2310
    /**
2311
     * @return array
2312
     */
2313
    public function mathematicOperatorsProvider()
2314
    {
2315
        return [['+'], ['-'], ['*'], ['/']];
2316
    }
2317
}
2318
2319
class MyAbsFunction extends FunctionNode
2320
{
2321
    public $simpleArithmeticExpression;
2322
2323
    /**
2324
     * @override
2325
     */
2326
    public function getSql(SqlWalker $sqlWalker)
2327
    {
2328
        return 'ABS(' . $sqlWalker->walkSimpleArithmeticExpression($this->simpleArithmeticExpression) . ')';
2329
    }
2330
2331
    /**
2332
     * @override
2333
     */
2334
    public function parse(Parser $parser)
2335
    {
2336
        $lexer = $parser->getLexer();
0 ignored issues
show
Unused Code introduced by
The assignment to $lexer is dead and can be removed.
Loading history...
2337
2338
        $parser->match(Lexer::T_IDENTIFIER);
2339
        $parser->match(Lexer::T_OPEN_PARENTHESIS);
2340
2341
        $this->simpleArithmeticExpression = $parser->SimpleArithmeticExpression();
2342
2343
        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
2344
    }
2345
}
2346
/**
2347
 * @Entity
2348
 */
2349
class DDC1384Model
2350
{
2351
    /**
2352
     * @Id
2353
     * @Column(type="integer")
2354
     * @GeneratedValue
2355
     */
2356
    protected $aVeryLongIdentifierThatShouldBeShortenedByTheSQLWalker_fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo;
2357
}
2358
2359
2360
/**
2361
 * @Entity
2362
 */
2363
class DDC1474Entity
2364
{
2365
2366
    /**
2367
     * @Id
2368
     * @Column(type="integer")
2369
     * @GeneratedValue()
2370
     */
2371
    protected $id;
2372
2373
    /**
2374
     * @column(type="float")
2375
     */
2376
    private $value;
2377
2378
    /**
2379
     * @param string $float
2380
     */
2381
    public function __construct($float)
2382
    {
2383
        $this->value = $float;
0 ignored issues
show
Documentation Bug introduced by
The property $value was declared of type double, but $float is of type string. Maybe add a type cast?

This check looks for assignments to scalar types that may be of the wrong type.

To ensure the code behaves as expected, it may be a good idea to add an explicit type cast.

$answer = 42;

$correct = false;

$correct = (bool) $answer;
Loading history...
2384
    }
2385
2386
    /**
2387
     * @return int
2388
     */
2389
    public function getId()
2390
    {
2391
        return $this->id;
2392
    }
2393
2394
    /**
2395
     * @return float
2396
     */
2397
    public function getValue()
2398
    {
2399
        return $this->value;
2400
    }
2401
2402
    /**
2403
     * @param float $value
2404
     */
2405
    public function setValue($value)
2406
    {
2407
        $this->value = $value;
2408
    }
2409
2410
}
2411