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

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

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

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

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

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

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

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

2
 Аватар для crautcher
2450 / 2301 / 597
Регистрация: 27.05.2011
Сообщений: 7,845
19.06.2015, 16:36
Лучший ответ Сообщение было отмечено 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
А в какой ситуации нужно получить название категории?

Если нужно вывести список новостей в разных категориях или просто список категорий, тогда действительно нужно считывать таблицу категорий (ну, или использовать LEFT JOIN). Если же речь идет об обращении к списку новостей в конкретной категории или к новости в ней, то из таблицы категорий достаточно прочитать только одну запись. Например, я отразила бы запрашиваемую категорию в адресе, по адресу определила бы категорию, а по категории уже бы прочитала список относящихся к ней новостей или конкретную запрашиваемую новость, если она относится именно к данной категории. Могу показать на примере.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.06.2015, 18:01
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru