function DatabaseSelectTestCase::testUnionOrder
Tests that we can UNION multiple Select queries together and set the ORDER.
File
-
modules/
simpletest/ tests/ database_test.test, line 1724
Class
- DatabaseSelectTestCase
- Test the SELECT builder.
Code
function testUnionOrder() {
// This gives George and Ringo.
$query_1 = db_select('test', 't')->fields('t', array(
'name',
))
->condition('age', array(
27,
28,
), 'IN');
// This gives Paul.
$query_2 = db_select('test', 't')->fields('t', array(
'name',
))
->condition('age', 26);
$query_1->union($query_2);
$query_1->orderBy('name', 'DESC');
$names = $query_1->execute()
->fetchCol();
// Ensure we get all 3 records.
$this->assertEqual(count($names), 3, 'UNION returned rows from both queries.');
// Ensure that the names are in the correct reverse alphabetical order,
// regardless of which query they came from.
$this->assertEqual($names[0], 'Ringo', 'First query returned correct name.');
$this->assertEqual($names[1], 'Paul', 'Second query returned correct name.');
$this->assertEqual($names[2], 'George', 'Third query returned correct name.');
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.