Форум программистов, компьютерный форум, киберфорум
PHP: Фреймворки
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
9 / 9 / 1
Регистрация: 09.08.2009
Сообщений: 109

Как получить связанные данных через relations и отобразить их через CActiveDataProvider?

27.02.2014, 17:45. Показов 1698. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день Уважаемые программисты!
Суть вопроса:
Имеется 3 таблицы, 2 из них реализованы как модели (Profile, Post) и 1 tbl_post_profile не имеет модели.
Структура представлена на изображении.

Как получить все Профили относящиеся к определенному Посту используя relations и отобразить их через CActiveDataProvider

Вот примерный код контроллера:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
$id = 3;
$data = array();
 
// получаем модель
$model = Post::model()->findByPk($id);
 
$criteria = new CDbCriteria;
 
// как вот тут здесь получить правильные данные через relations ( т.е. профили 1, 4, 5 )
$criteria->with = array('relat', array(
    'condition' => 'post_id = :post_id',
    'params' => array(':post_id' => $id),
));
 
// и отобразить эти данные через CActiveDataProvider
$data['dataProvider'] = new CActiveDataProvider('Profile', array(
    'pagination' => array(
        'pageSize' => 10,
    ),
    'criteria' => $criteria,
));

Как правильно реализовать relations ?
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
class Profile extends CActiveRecord{
    
    public function relations()
    {
        return array(
            // как правильно реализовать ???
            'relat' => array(self::MANY_MANY, 'Post', 'tbl_post_profile(post_id, user_id)', 'index' => 'user_id', 'together' => false),
            // или
            'relat' => array(self::HAS_MANY, 'Post', 'tbl_post_profile(post_id, user_id)', 'index' => 'post_id', 'together' => false),
            
        );
    }
}
Миниатюры
Как получить связанные данных через relations и отобразить их через CActiveDataProvider?  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.02.2014, 17:45
Ответы с готовыми решениями:

Как отобразить через Combobox в datagridview значение 1-й связанной таблицы через 2-ю и записать знач 2-й в 3
Здравствуйте. Уперся в необычную для меня проблему:как отобразить через Combobox в datagridview значение 1-й связанной таблицы через 2-ю и...

Отображение данных в Treeview через БД Access и связанные таблицы в нём
Добрый день всем! Подскажите, пожалуйста, кто сталкивался или имеет готовый прототип. P.S. нуб 5 lvl, до этого кодил чуть на C++,...

Как получить несколько данных с UI через href?
Добрый день. отправляю такой код из JS $('.saveEdit').click(function (e) { var id = $(this).data('customer-id'); ...

2
365 / 372 / 89
Регистрация: 01.12.2013
Сообщений: 1,629
27.02.2014, 17:59
Цитата Сообщение от component6 Посмотреть сообщение
Как правильно реализовать relations ?
Так как написано в инструкции к фреймворку.
Можно предположить, что фреймворк это yii, а ваш вопрос означает "почему не работает?"
Тогда, чтобы работали связи между АР, нужно создавать все три модели...
0
9 / 9 / 1
Регистрация: 09.08.2009
Сообщений: 109
27.02.2014, 21:36  [ТС]
Цитата Сообщение от ads Посмотреть сообщение
нужно создавать все три модели...
Могу с Вами не согласиться, нет необходимости создавать третью модель для промежуточной таблицы

http://www.yiiframework.com/do... tabase.arr

PHP
1
2
3
4
5
6
7
8
9
10
11
12
class Post extends CActiveRecord
{
    …
    public function relations()
    {
        return array(
            'author'=>array(self::BELONGS_TO, 'User', 'author_id'),
            'categories'=>array(self::MANY_MANY, 'Category',
                'tbl_post_category(post_id, category_id)'),
        );
    }
}
Добавлено через 1 час 27 минут
Собственно вопрос остался открытым. Уточню.

Мы имеем id модели Post
Цитата Сообщение от component6 Посмотреть сообщение
$id = 3;
Как использую new CDbCriteria и relations получить только те записи из Profile, которые находятся в промежуточной таблице tbl_post_profile (т.е. записи с идентификаторами 1, 4, 5)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.02.2014, 21:36
Помогаю со студенческими работами здесь

Отправить текст из Edit через WSASend, получить ответ и отобразить его в Memo
всем привет! не могу найти пример WSASend нормальный, мне над отправить с Edit текст через WSASend и потом получить любой ответ и...

Как программе через пароль получить доступ к базы данных?
Если я поставил пароль на базу данных. То как программе через пароль получить доступ до базы данных? Я хачу хранить список ников и...

Как отобразить boolean через chekbox?
Задача - реализовать страницу для редактирования конфигов, html страницу сделал, значения отображаются, кроме boolean значений, кусок...

Как отобразить отчет, сгенерированный в ncreport через qt?
Добрый день. Подскажите пожалуйста, кто знает, пошаговое, что куда прописать, чтобы отчет ncreport открывался в qt... Вот мой код: ...

Как отобразить ДРОБНЫЕ данные через точку
У меня связь с БД через ADO (ADOQUERY->). дАННЫЕ НА ЭКРАНЕ из SQL-запроса отображаются. Кто знает,как данные ,не целые числа , на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru