Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
0 / 0 / 0
Регистрация: 19.06.2015
Сообщений: 1
1

Связь между таблицами

19.06.2015, 16:27. Показов 1397. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго времени суток!
Мне нужна Ваша помощь. Создаю новостной сайт.
Есть две таблицы в БД:
1. news, список всех новостей, имеется столбик cat_id(записывается категория новости, цифрами)
2. section, список новостных категорий. Столбики id, category(Экономика,Спорт,Мир)

Делаю запрос mysqli_query($connect, "SELECT * FROM `news` ORDER BY `id` DESC"); и затем вывод новостей.
И теперь вот в чем заключается мой вопрос:
При выводе названия категории над новостью, естественно выводит цифру. Как сделать связь между двумя таблицами, чтобы выводило к примеру не 1, а "Экономика".
Очень надеюсь на Вашу помощь. Извиняюсь, если что-то не корректно написал, мне далеко еще до профи, но я готов учиться.
Спасибо!
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.06.2015, 16:27
Ответы с готовыми решениями:

Связь между таблицами
Здравствуйте! PHP только начал изучать. Есть 4 таблицы: 1. Оборудование id name 1 axc 2 axcz...

Связь между 2 таблицами и занос в 1 из таблиц
У меня есть 2 таблицы. в 1 таблице есть. id и catalog во 2 таблице id и id_catalog Мне нужно...

Связь между двумя и более таблицами
Здравствуйте. Сделал БД через phpmyadmin, нормализовал по первым трем НФ. Простейшие запросы на...

Как наладить связь между таблицами в mysql так, чтобы при удалении, удалялись все таблицы, связанные с этой. И еще о "призрачных записях"
У меня есть таблица clients, в ней есть поля contacts_id, где цифра ведет к таблице contacts по id....

2
2433 / 2285 / 594
Регистрация: 27.05.2011
Сообщений: 7,808
19.06.2015, 16:36 2
Лучший ответ Сообщение было отмечено sanyochek как решение

Решение

MySQL
1
2
3
4
SELECT * FROM `news` n 
left join `section` s  
on n.`cat_id` = s.`id`
ORDER BY n.`id` DESC
Добавлено через 2 минуты
Но это туповато, так как к каждой записи будет тянуться категория, а поскольку они повторяются, то вы тяните много дублей. Вариант 2:
первый запрос не меняем,
В цикле собираем все cat_id в массив, а затем достаем категории
PHP
1
"from `section` where id in ('". join("','" , $cat_ids) ."')"
0
Заблокирован
19.06.2015, 18:01 3
А в какой ситуации нужно получить название категории?

Если нужно вывести список новостей в разных категориях или просто список категорий, тогда действительно нужно считывать таблицу категорий (ну, или использовать LEFT JOIN). Если же речь идет об обращении к списку новостей в конкретной категории или к новости в ней, то из таблицы категорий достаточно прочитать только одну запись. Например, я отразила бы запрашиваемую категорию в адресе, по адресу определила бы категорию, а по категории уже бы прочитала список относящихся к ней новостей или конкретную запрашиваемую новость, если она относится именно к данной категории. Могу показать на примере.
0
19.06.2015, 18:01
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.06.2015, 18:01
Помогаю со студенческими работами здесь

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

Связи между таблицами не отображаются
У меня в phpmyadmin в designer есть таблицы, но связи между ними не отображаются. В чем проблема...

Связи между таблицами в MyPhpAdmin
Здравствуйте. Создала таблицы: Страны, Страны-туры, Туры. Связала таблицы Страны и Страны-туры по...

Связи между таблицами в Mysql
Всем привет! При создании схемы БД, наткнулся на такой вопрос: Например у нас есть таблица...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru