DatabaseSelectTestCase::testUnion

7 database_test.test DatabaseSelectTestCase::testUnion()
8 database.test DatabaseSelectTestCase::testUnion()

Test that we can UNION multiple Select queries together. This is semantically equal to UNION DISTINCT, so we don't explicity test that.

File

modules/simpletest/tests/database_test.test, line 1492

Code

function testUnion() {
  $query_1 = db_select('test', 't')
      ->fields('t', array('name'))
      ->condition('age', array(27, 28), 'IN');

  $query_2 = db_select('test', 't')
      ->fields('t', array('name'))
      ->condition('age', 28);

  $query_1->union($query_2);

  $names = $query_1->execute()->fetchCol();

  // Ensure we only get 2 records.
  $this->assertEqual(count($names), 2, t('UNION correctly discarded duplicates.'));

  $this->assertEqual($names[0], 'George', t('First query returned correct name.'));
  $this->assertEqual($names[1], 'Ringo', t('Second query returned correct name.'));
}
Login or register to post comments