1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- <?php
- /**
- * @link https://www.yiiframework.com/
- * @copyright Copyright (c) 2008 Yii Software LLC
- * @license https://www.yiiframework.com/license/
- */
- namespace yii\db\sqlite\conditions;
- use yii\base\NotSupportedException;
- use yii\db\Expression;
- /**
- * {@inheritdoc}
- *
- * @author Dmytro Naumenko <d.naumenko.a@gmail.com>
- * @since 2.0.14
- */
- class InConditionBuilder extends \yii\db\conditions\InConditionBuilder
- {
- /**
- * {@inheritdoc}
- * @throws NotSupportedException if `$columns` is an array
- */
- protected function buildSubqueryInCondition($operator, $columns, $values, &$params)
- {
- if (is_array($columns)) {
- throw new NotSupportedException(__METHOD__ . ' is not supported by SQLite.');
- }
- return parent::buildSubqueryInCondition($operator, $columns, $values, $params);
- }
- /**
- * {@inheritdoc}
- */
- protected function buildCompositeInCondition($operator, $columns, $values, &$params)
- {
- $quotedColumns = [];
- foreach ($columns as $i => $column) {
- if ($column instanceof Expression) {
- $column = $column->expression;
- }
- $quotedColumns[$i] = strpos($column, '(') === false ? $this->queryBuilder->db->quoteColumnName($column) : $column;
- }
- $vss = [];
- foreach ($values as $value) {
- $vs = [];
- foreach ($columns as $i => $column) {
- if ($column instanceof Expression) {
- $column = $column->expression;
- }
- if (isset($value[$column])) {
- $phName = $this->queryBuilder->bindParam($value[$column], $params);
- $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' = ' : ' != ') . $phName;
- } else {
- $vs[] = $quotedColumns[$i] . ($operator === 'IN' ? ' IS' : ' IS NOT') . ' NULL';
- }
- }
- $vss[] = '(' . implode($operator === 'IN' ? ' AND ' : ' OR ', $vs) . ')';
- }
- return '(' . implode($operator === 'IN' ? ' OR ' : ' AND ', $vss) . ')';
- }
- }
|