Yii: Как использовать IF в CDbCriteria в MySQL запросе select в контроллере
Например, у меня есть в талице MySQL поле дата окончания. В контроллере я отбираю из этой таблицы все записи, располагаю их по убыванию, но, вдруг, хочу, чтобы "дата окончания" сравнивалась с текущей датой и в зависимости от результата, визуально записи раскрашивались. Серым цветом – то, что уже прошло, зелёненьким – то, что ещё не завершилось.
Но городить огород не хочется каменный, хочется просто и эффективно, чтобы работало. Тут я и использую оператор IF в CDbCriteria в строке запроса mysql select.
В контроллер добавляю это самое сравнение (дописываю sql запрос):
public function actionIndex()
{
$criteria=new CDbCriteria(array(
'order'=>'date_start DESC',
'with'=>'author',
));
$criteria->select = array(
'*',
'IF(date_finish<= CURDATE(), "pasttrip", "futuretrip") AS pastorfuture',
);
...
$dataProvider=new CActiveDataProvider('Trip', array(
'pagination'=>array(
'pageSize'=>Yii::app()->params['tripsPerPage'],
),
'criteria'=>$criteria,
));
class Trip extends CActiveRecord { public $pastorfuture; ...
<div class="view <?php echo $data->pastorfuture;?>"> ...
.pasttrip { background: #dcdcdc; } .futuretrip { background: #e6faca; }
almix
Разработчик Loco, автор статей по веб-разработке на Yii, CodeIgniter, MODx и прочих инструментах. Создатель Team Sense.
Вы можете почитать все статьи от almix'а.
- 14 Разработка приложения на Yii. Урок 14: Выводим список категорий как новый виджет на сайте (29.04.2015)
- 13 Разработка приложения на Yii. Урок 13: Внедряем категории для статей. (29.04.2015)
- 12 Разработка приложения на Yii. Урок 12: Профилирование приложения, включаем кеширование. (20.01.2015)
- 11 Yiico. Видеокурс по разработке сайта на Yii. Урок 11: Отладка приложения, включаем журналирование. (20.01.2015)
- 10 Yiico. Видеокурс по разработке сайта на Yii. Урок 10: Если ваше приложение находится не в корневой папке, а во вложенной. (19.10.2014)
- 9 Разработка сайта на Yii с нуля. Урок 9. Выборка статей определённого автора. (13.08.2014)
- 8 Разработка сайта на Yii с нуля. Урок 8. Вызов в моделях функции, общей для них. Как избегать дублирования кода? (25.07.2014)
- 7 Разработка сайта на Yii с нуля. Урок 7. Изменение количества выводимых записей на странице в CGridView. Включаем сессии Yii. (04.09.2013)
- 6 Разработка сайта на Yii с нуля. Урок 6. Автоматич. отправка оповещений об одобренных комментариях на email автора комментария (11.08.2013)
- 5 Разработка сайта на Yii с нуля. Урок 5. Переименовываем blog в yiico. Изменяем "Home" в breadcrumbs. Включаем Gzip-сжатие. (09.08.2013)
- 4 Курс по Yii с нуля. Урок 4. Дорабатываем простую работу с пользователями: хранение пароля при редактировании пользователя. (13.04.2013)
- 3 Курс по Yii с нуля. Урок 3. Создаём новых пользователей. Организуем простую систему авторизации. Аутентификация, пароли, соли. (20.07.2014)
- 2 Yii + Git (github) на Mac. (24.03.2013)
- 2 Курс по Yii с нуля. Урок 2. Переносим и настраиваем Yii и проект нашего сайта на рабочем сервере. Избавляемся от index.php в url (09.07.2014)
- 1 Курс по Yii с нуля. Урок 1. Устанавливаем Yii на локальном компьютере. Заводим проект будущего сайта. (10.03.2013)
- 0 Composer – пакетный менеджер PHP. Что и как? (22.07.2014)
- 0 MySQL: проверить содержится ли значение в поле столбца (в столбце хранится строка значений через запятую) (22.05.2014)
- 0 Yii: Статичные страницы (создание, редактирование, удаление) (28.04.2014)
- 0 Yii: Расширение ECKEditor = Связка ckeditor + kcfinder (визуальный редактор с бесплатным файловым менеджером) (28.04.2014)
- 0 Yii: Bootstrap tabs, делаем активной вкладку на которую выполняется переход по ссылке (20.03.2014)
- 0 Yii: Доступ к атрибуту модели из файла шаблона (Вызов в шаблоне какого-либо атрибута модели). (17.02.2014)
- 0 Yii: Множественный автокомплит с помощью CJuiAutoComplete (автокомплит нескольких значений в одно поле) (07.02.2014)
- 0 Yii: Фотогалерея через поведение (доработка расширения imagesgallerymanager) (08.03.2016)
- 0 Yii: Установка и настройка Yii-app заготовки приложения от Crisu83 (09.03.2014)
- 0 Twitter Bootstrap Carousel Crossfade (09.09.2013)
2 комментариев
Очень оригинально.
1. Формирование критерия в контроллере - это круто. Все принципы MVC - побоку. Такие вещи или в модели делаются или в сервисном слое...
2. Проверка на прошлое и будущее через запрос БД - аналогично. Не правильнее ли в представлении проверять посредством PHP?
3. Насколько я помню в Yii для отображения подобных вещей был CListView. А там при помощи несложных манипуляций можно и окрашивание в разные цвета приклеить, как и в CGridView.
Serge,
1) Вы правы, но, в контроллере же работает. Мне главное, чтобы работало.
2) Тогда из базы выберутся лишние записи, и в виде уже их отсекать придётся. А так сразу выбираю только то, что необходимо. Или я не прав?
3) да, вот - CGridView - how to color rows depending on data values.