UpdateComplexTest.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. <?php
  2. namespace Drupal\KernelTests\Core\Database;
  3. use Drupal\Core\Database\Query\Condition;
  4. /**
  5. * Tests the Update query builder, complex queries.
  6. *
  7. * @group Database
  8. */
  9. class UpdateComplexTest extends DatabaseTestBase {
  10. /**
  11. * Tests updates with OR conditionals.
  12. */
  13. public function testOrConditionUpdate() {
  14. $update = db_update('test')
  15. ->fields(['job' => 'Musician'])
  16. ->condition((new Condition('OR'))
  17. ->condition('name', 'John')
  18. ->condition('name', 'Paul')
  19. );
  20. $num_updated = $update->execute();
  21. $this->assertIdentical($num_updated, 2, 'Updated 2 records.');
  22. $num_matches = db_query('SELECT COUNT(*) FROM {test} WHERE job = :job', [':job' => 'Musician'])->fetchField();
  23. $this->assertIdentical($num_matches, '2', 'Updated fields successfully.');
  24. }
  25. /**
  26. * Tests WHERE IN clauses.
  27. */
  28. public function testInConditionUpdate() {
  29. $num_updated = db_update('test')
  30. ->fields(['job' => 'Musician'])
  31. ->condition('name', ['John', 'Paul'], 'IN')
  32. ->execute();
  33. $this->assertIdentical($num_updated, 2, 'Updated 2 records.');
  34. $num_matches = db_query('SELECT COUNT(*) FROM {test} WHERE job = :job', [':job' => 'Musician'])->fetchField();
  35. $this->assertIdentical($num_matches, '2', 'Updated fields successfully.');
  36. }
  37. /**
  38. * Tests WHERE NOT IN clauses.
  39. */
  40. public function testNotInConditionUpdate() {
  41. // The o is lowercase in the 'NoT IN' operator, to make sure the operators
  42. // work in mixed case.
  43. $num_updated = db_update('test')
  44. ->fields(['job' => 'Musician'])
  45. ->condition('name', ['John', 'Paul', 'George'], 'NoT IN')
  46. ->execute();
  47. $this->assertIdentical($num_updated, 1, 'Updated 1 record.');
  48. $num_matches = db_query('SELECT COUNT(*) FROM {test} WHERE job = :job', [':job' => 'Musician'])->fetchField();
  49. $this->assertIdentical($num_matches, '1', 'Updated fields successfully.');
  50. }
  51. /**
  52. * Tests BETWEEN conditional clauses.
  53. */
  54. public function testBetweenConditionUpdate() {
  55. $num_updated = db_update('test')
  56. ->fields(['job' => 'Musician'])
  57. ->condition('age', [25, 26], 'BETWEEN')
  58. ->execute();
  59. $this->assertIdentical($num_updated, 2, 'Updated 2 records.');
  60. $num_matches = db_query('SELECT COUNT(*) FROM {test} WHERE job = :job', [':job' => 'Musician'])->fetchField();
  61. $this->assertIdentical($num_matches, '2', 'Updated fields successfully.');
  62. }
  63. /**
  64. * Tests LIKE conditionals.
  65. */
  66. public function testLikeConditionUpdate() {
  67. $num_updated = db_update('test')
  68. ->fields(['job' => 'Musician'])
  69. ->condition('name', '%ge%', 'LIKE')
  70. ->execute();
  71. $this->assertIdentical($num_updated, 1, 'Updated 1 record.');
  72. $num_matches = db_query('SELECT COUNT(*) FROM {test} WHERE job = :job', [':job' => 'Musician'])->fetchField();
  73. $this->assertIdentical($num_matches, '1', 'Updated fields successfully.');
  74. }
  75. /**
  76. * Tests UPDATE with expression values.
  77. */
  78. public function testUpdateExpression() {
  79. $before_age = db_query('SELECT age FROM {test} WHERE name = :name', [':name' => 'Ringo'])->fetchField();
  80. $num_updated = db_update('test')
  81. ->condition('name', 'Ringo')
  82. ->fields(['job' => 'Musician'])
  83. ->expression('age', 'age + :age', [':age' => 4])
  84. ->execute();
  85. $this->assertIdentical($num_updated, 1, 'Updated 1 record.');
  86. $num_matches = db_query('SELECT COUNT(*) FROM {test} WHERE job = :job', [':job' => 'Musician'])->fetchField();
  87. $this->assertIdentical($num_matches, '1', 'Updated fields successfully.');
  88. $person = db_query('SELECT * FROM {test} WHERE name = :name', [':name' => 'Ringo'])->fetch();
  89. $this->assertEqual($person->name, 'Ringo', 'Name set correctly.');
  90. $this->assertEqual($person->age, $before_age + 4, 'Age set correctly.');
  91. $this->assertEqual($person->job, 'Musician', 'Job set correctly.');
  92. }
  93. /**
  94. * Tests UPDATE with only expression values.
  95. */
  96. public function testUpdateOnlyExpression() {
  97. $before_age = db_query('SELECT age FROM {test} WHERE name = :name', [':name' => 'Ringo'])->fetchField();
  98. $num_updated = db_update('test')
  99. ->condition('name', 'Ringo')
  100. ->expression('age', 'age + :age', [':age' => 4])
  101. ->execute();
  102. $this->assertIdentical($num_updated, 1, 'Updated 1 record.');
  103. $after_age = db_query('SELECT age FROM {test} WHERE name = :name', [':name' => 'Ringo'])->fetchField();
  104. $this->assertEqual($before_age + 4, $after_age, 'Age updated correctly');
  105. }
  106. /**
  107. * Test UPDATE with a subselect value.
  108. */
  109. public function testSubSelectUpdate() {
  110. $subselect = db_select('test_task', 't');
  111. $subselect->addExpression('MAX(priority) + :increment', 'max_priority', [':increment' => 30]);
  112. // Clone this to make sure we are running a different query when
  113. // asserting.
  114. $select = clone $subselect;
  115. $query = db_update('test')
  116. ->expression('age', $subselect)
  117. ->condition('name', 'Ringo');
  118. // Save the number of rows that updated for assertion later.
  119. $num_updated = $query->execute();
  120. $after_age = db_query('SELECT age FROM {test} WHERE name = :name', [':name' => 'Ringo'])->fetchField();
  121. $expected_age = $select->execute()->fetchField();
  122. $this->assertEqual($after_age, $expected_age);
  123. $this->assertEqual(1, $num_updated, t('Expected 1 row to be updated in subselect update query.'));
  124. }
  125. }