InConditionBuilder.php 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\db\mssql\conditions;
  8. use yii\base\NotSupportedException;
  9. use yii\db\Expression;
  10. /**
  11. * {@inheritdoc}
  12. *
  13. * @author Dmytro Naumenko <d.naumenko.a@gmail.com>
  14. * @since 2.0.14
  15. */
  16. class InConditionBuilder extends \yii\db\conditions\InConditionBuilder
  17. {
  18. /**
  19. * {@inheritdoc}
  20. * @throws NotSupportedException if `$columns` is an array
  21. */
  22. protected function buildSubqueryInCondition($operator, $columns, $values, &$params)
  23. {
  24. if (is_array($columns)) {
  25. throw new NotSupportedException(__METHOD__ . ' is not supported by MSSQL.');
  26. }
  27. return parent::buildSubqueryInCondition($operator, $columns, $values, $params);
  28. }
  29. /**
  30. * {@inheritdoc}
  31. */
  32. protected function buildCompositeInCondition($operator, $columns, $values, &$params)
  33. {
  34. $quotedColumns = [];
  35. foreach ($columns as $i => $column) {
  36. if ($column instanceof Expression) {
  37. $column = $column->expression;
  38. }
  39. $quotedColumns[$i] = strpos($column, '(') === false ? $this->queryBuilder->db->quoteColumnName($column) : $column;
  40. }
  41. $vss = [];
  42. foreach ($values as $value) {
  43. $vs = [];
  44. foreach ($columns as $i => $column) {
  45. if ($column instanceof Expression) {
  46. $column = $column->expression;
  47. }
  48. if (isset($value[$column])) {
  49. $phName = $this->queryBuilder->bindParam($value[$column], $params);
  50. $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' = ' : ' != ') . $phName;
  51. } else {
  52. $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' IS' : ' IS NOT') . ' NULL';
  53. }
  54. }
  55. $vss[] = '(' . implode($operator === 'IN' ? ' AND ' : ' OR ', $vs) . ')';
  56. }
  57. return '(' . implode($operator === 'IN' ? ' OR ' : ' AND ', $vss) . ')';
  58. }
  59. }