Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
 Аватар для Rurr
23 / 23 / 11
Регистрация: 12.01.2013
Сообщений: 223

Запрос, учитывая значения полей другой таблицы

17.07.2016, 01:28. Показов 778. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Итак есть таблица cat с полями (id, name, link) - Категории и их имена.
и таблица categories в которой есть id и некое количество столбцов равное количеству записей в таблице cat, и имена этих столбцов равны значениям поля link в таблице cat

Нужно получить cat.name имея только categories.id.

Сейчас реализовано двумя запросами к базе. Помогите составить единственный запрос.

Спасибо большое за внимание.

Добавлено через 4 часа 27 минут
сейчас реализована вот так:
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
    function showNewsCategories(){
        if(isset($this->singleNews['id'])){
            $query = mysqli_query($this->db, "SELECT * FROM categories WHERE id='".$this->singleNews['id']."'");
            if($query){
                $cats = mysqli_fetch_assoc($query);
                $qstr = false;
                foreach($cats as $key => $val){
                    if($val == 1){
                        if($qstr){
                            $condition = " OR ";
                        }else{
                            $condition = "";
                        }
                        $qstr = $qstr.$condition." link='".$key."'";
                    }
                }
                $query = mysqli_query($this->db, "SELECT name FROM cat WHERE ".$qstr);
                if($query and mysqli_num_rows($query) > 0){
                    $koma = False;
                    while($ct = mysqli_fetch_assoc($query)){
                        if($koma){
                            $sym = ", ";
                        }else{
                            $sym = " ";
                            $koma = True;
                        }
                        print $sym.$ct['name'];
                    }
                }
            }
        }
    }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.07.2016, 01:28
Ответы с готовыми решениями:

Запрос, возвращающий значения поля одной таблицы и складывающий эти значения в поле другой таблицы
доборого дня всем, подскажите процедуру которая будет возвращать значение поля одной таблицы и складывать эти значения в поле другой...

Перенос значения таблицы в имена полей SQL запрос
Табличка: Перенести значения столбца с названиями предметов в поля в новый запрос. Схема даних:

Вывести данные из таблицы, учитывая параметры из другой
Всем привет, не могу разобраться, как правильно вывести данные. Есть две таблицы. Первая - товары Goods (id, good_name). Вторая - продажи...

5
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
17.07.2016, 03:36
Rurr, ИМХО, с такой структурой БД получить name одним запросом нельзя.
были бы категории строками, а не именами столбцов, то можно было бы так
MySQL
1
2
3
4
5
SELECT `name` FROM `cat`
    WHERE `link` in (
        SELECT `cat_id` FROM `categories`
            WHERE `news_id` = :id
    )
1
 Аватар для Rurr
23 / 23 / 11
Регистрация: 12.01.2013
Сообщений: 223
19.07.2016, 23:55  [ТС]
тогда может посоветуете более оптимальную структуру?
0
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
20.07.2016, 00:22
Цитата Сообщение от Rurr Посмотреть сообщение
тогда может посоветуете более оптимальную структуру?
Это смотря что нужно сделать...
0
 Аватар для Rurr
23 / 23 / 11
Регистрация: 12.01.2013
Сообщений: 223
20.07.2016, 01:33  [ТС]
одна запись может соответствовать нескольким категориям, я храню имена категорий в отдельной таблице, записи в другой а соответствия в третей, при чем количество категорий может менятся. Здесь же на форуме читал что такой вариант самый оптимальный
0
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
20.07.2016, 01:58
Rurr, это стандартное решение для данной задачи:
  • таблица "записи" с полями id записи, текст, дата, id автора
  • таблица "категории" с полями id категории, название, описание, возможно - id родительской категории - для построения дерева
  • ну и связующая таблица "записи-категории" id записи + id категории
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.07.2016, 01:58
Помогаю со студенческими работами здесь

LIKE для LINQ: Сделать запрос на выбор значений, содержащих в себе значения из другой таблицы
Имеется две таблицы. Table1 Ивановский Петр Петрович Иванович Автоивановск Петров

Запрос, который выведет таблицу с двумя колонками содержащими значения одной колонки другой таблицы
Никак не могу понять, каким запросом можно вывести таблицу с двумя колонками содержащими значения одной колонки другой таблицы. Скорее...

Как полю одной таблицы задать несколько полей другой таблицы?
Вообщем не могу понять как создать вот такую схему: Есть таблица размещения документов: например: id|desc точка 1|описание точки...

Поле таблицы как сумма значений полей другой таблицы
Здравствуйте. В процессе создания БД столкнулся с проблемой, которую сам решить уже не могу. Есть 2 таблицы "Договор" и...

Ограничить значение поля таблицы значениями полей другой таблицы
У меня в БД есть две таблицы: 1) Дома. Поля: id, дата постройки, дата сноса; 2) Жильцы. Поля: id, id_дом, дата заселения. Как в БД...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
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