Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 2
Регистрация: 01.01.2015
Сообщений: 96

Переход на другую страницу с сохранением данных из таблиц(многие ко многим)

27.07.2017, 16:36. Показов 1177. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет.
Есть функции -
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
 public function getArticles(){
        // $articleResult = $this->pdo->query("SELECT * FROM `articles` ORDER BY `id` DESC");
       
        $articleResult = $this->pdo->query(
            "SELECT s.id, s.title, s.text, s.date, GROUP_CONCAT(t.name) AS tags, GROUP_CONCAT(t.id) AS tagsId, GROUP_CONCAT(t.alias) AS alias
           FROM articles AS s
           LEFT JOIN articleTags AS aT on s.id = aT.articleID
           LEFT JOIN tags AS t ON aT.tagID = t.id
           GROUP BY s.id"
        );)  
 
        $articles = $articleResult->fetchAll(PDO::FETCH_ASSOC);
        foreach($articles as $k => $v){
            $articles[$k]['a_tags'] = self::buildTags2($v['tagsId'], $v['alias'], $v['tags']);
        }
 
       
        return $articles;
 
    }
static function buildTags2($keys, $aliases, $tags){
            $result = array();
            if(!empty($keys)){
 
                $keys = explode(',', $keys);
                $aliases = explode(',', $aliases);
                $tags = explode(',', $tags);
 
                foreach ($keys as $k => $v){
                    $result[$v] = array(
                        'alias' => $aliases[$k],
                        'tag' => $tags[$k],
                    );
                }
            }
            return $result;
        }
Эти функции привязывают к статьям теги, через промежуточную таблицу.
Вопрос - как лучше сделать запрос после перехода на статью? Что бы теги были видны? Добавить параметр в getArticles($id) потом что то типа
PHP
1
2
3
4
getArticles($id){
$where = "WHERE `id` = ".$id;
$articleResult = $this->pdo->query("SELECT ... FROM articles $where ...
}
Или лучше создать новый метод?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.07.2017, 16:36
Ответы с готовыми решениями:

Вывод данных из таблиц. Многие ко многим
Здравствуйте. Столкнулся с проблемой. При выводе данных с таблицы на форму (достаю через SQL запрос - будет ниже) получаю немного не то,...

Выбрать из таблиц со связью многие ко многим
Здравствуйте! Помогите составить запрос. Суть такая: имеются две таблицы, между ними связь многие ко многим. В первой таблице информация по...

Заполнение таблиц с связью многие-ко-многим
Есть две таблицы Artists и Performers. Между ними установлена связь многие ко многим и автоматически создана таблица связки Groups...

1
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
30.07.2017, 11:09
SQL
1
SELECT * FROM tags LEFT JOINS articles ON tags.article_id=articles.id WHERE articles.id = 1
либо отдельно получать статью и отдельно теги
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.07.2017, 11:09
Помогаю со студенческими работами здесь

Выборка из связанных таблиц (многие-ко-многим)
Классический случай: таблица книг, таблица авторов, промежуточная таблица. -8 8- Можно ли одним запросом выбрать интересующую...

Отображение таблиц со связью многие ко многим
Есть две таблицы, между которыми установлена связь многие ко многим, через третью таблицу: books(bookID) authors(authorID) ...

Запрос Многие-ко-Многим ( связь большого количества таблиц)
К таблице Application нужно как то прикрепить некоторое оборудование, нужно получить название или id используемого оборудования. Голову...

Заполнение таблиц многие ко многим - Как добавлять в корзину сразу несколько фруктов?
Добрый день! В существующей БД со связью многие ко многим заполнение формы "Урожай" реализовано с помощью Combobox. ...

Как осуществить поиск данных по базе данных по связи многие-ко-многим
Репозиторий SqlApplicantRepository namespace theModel.Repository { public class SqlApplicantRepository:IApplicantRepository ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru