С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
6 / 6 / 1
Регистрация: 19.12.2013
Сообщений: 160

Выборка данных 2 раза из одной таблицы

24.11.2015, 22:37. Показов 1838. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер.
Такая ситуация:
Есть таблица рейсы. В ней есть столбец начальный город и конечный.
Есть таблица города.
Как вытянуть эти данные?

P.s. такая же ситуация с таблицами рейсы и сотрудники

PHP
1
2
3
4
5
6
$query="SELECT * FROM Route r LEFT JOIN Workers w ON (r.Driver=w.ID AND r.Conductor=w.ID) LEFT JOIN Bus b ON r.Bus=b.ID LEFT JOIN City c ON (r.FrCity=c.ID AND r.ToCity=c.ID)";
        $data=mysqli_query($dbc, $query) or die(mysqli_error($dbc));
        while($row = mysqli_fetch_array($data))
        {   
                ???????
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.11.2015, 22:37
Ответы с готовыми решениями:

Sql запрос. Из одной таблицы два раза
Здравтсвуйте. Есть две таблицы, в которым такая структура данных. Талица "Краткий маршрут" Код Начальная Конечная 1 ...

Выборка сразу нескольких значений с одной таблицы
Добрый день. Нужна помощь. Есть ужасная таблица с кучей информации. Хочу вытянуть определенные данные в правильном порядке. есть mysql...

Выборка из таблицы: по одной записи от каждого пользователя
Допустим есть таблица а в ней много сообщений от разных пользователей, подскажите как сделать выборку из таблицы чтобы вывело по 1 записи...

8
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
25.11.2015, 00:02
Цитата Сообщение от Julieta Посмотреть сообщение
Как вытянуть эти данные?
Какие?
Цитата Сообщение от Julieta Посмотреть сообщение
Есть таблица рейсы. В ней есть столбец начальный город и конечный.
Есть таблица города.
А схема этих таблиц - гостайна?
По тем данным что есть максимум что можно сказать - 2 раза джойнить таблицу с городами по совпадению id, или еще чего, через что они связаны.
0
6 / 6 / 1
Регистрация: 19.12.2013
Сообщений: 160
25.11.2015, 00:07  [ТС]
Jewbacabra,

Вот схема.

Цитата Сообщение от Jewbacabra Посмотреть сообщение
Какие?
Например мне нужно вывести таблицу:
№Рейса, начальный город, конечный город, водитель, кондуктор, дата.
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
25.11.2015, 00:19
Добавлено через 5 минут
Номер это ID?
SQL
1
2
3
4
5
6
7
8
9
SELECT r.`ID`, f.`Name`, t.`Name`, CONCAT(d.`Name`, ' ', d.`MiddleName` ,' ', d.`SurName`), CONCAT(c.`Name`, ' ', c.`MiddleName` ,' ', c.`SurName`), r.`Date` FROM `Route` r
JOIN `City` f ON
    r.`FrCity` = f.`ID`
JOIN `City` t ON
    r.`ToCity` = t.`ID`
JOIN `Workers` d ON
    r.`Driver` = d.`ID`
JOIN `Workers` c ON
    r.`Conductor` = c.`ID`
0
6 / 6 / 1
Регистрация: 19.12.2013
Сообщений: 160
25.11.2015, 00:21  [ТС]
Jewbacabra, Так в этом то и вопрос?) Как вывести. Например имя водителя. В таблице Route это Driver, а вот в таблице сотрудников это просто Name (а там может быть как и кондуктор, так и водитель).
Если бы можно было как-то:
if (r.`Driver`=d.`ID`) echo "Водитель: $row[ID]";

Добавлено через 50 секунд
Цитата Сообщение от Jewbacabra Посмотреть сообщение
Номер это ID?
Да, но это не так важно) мне бы разобраться как это условие организовать)
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
25.11.2015, 00:27
Если правильно понял вопрос:
SQL
1
SELECT r.`ID` AS `Number`, f.`Name` AS `FromCityName`, ...
в php
PHP
1
2
echo $row['ID'];
echo $row['FromCityNumber'];
0
6 / 6 / 1
Регистрация: 19.12.2013
Сообщений: 160
25.11.2015, 00:32  [ТС]
Цитата Сообщение от Jewbacabra Посмотреть сообщение
Если правильно понял вопрос:
SQLВыделить код
1
SELECT r.`ID` AS `Number`, f.`Name` AS `FromCityName`, ...
в php
PHPВыделить код
1
2
echo $row['ID'];
echo $row['FromCityNumber'];
Но ведь оно 2 города пустит как FromCityName? нет? как оно поймет что это этот?
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
25.11.2015, 00:38
Лучший ответ Сообщение было отмечено Julieta как решение

Решение

Цитата Сообщение от Julieta Посмотреть сообщение
как оно поймет что это этот?
Второму другое имя дать:
SQL
1
SELECT r.`ID` AS `Number`, f.`Name` AS `FromCityName`, t.`Name` AS `ToCityName`, ...
т.е FromCityName из таблицы f, а f - в 1 джоине.
ToCityName из t, которая во втором джоине.
1
6 / 6 / 1
Регистрация: 19.12.2013
Сообщений: 160
25.11.2015, 00:43  [ТС]
Jewbacabra, я не совсем понимаю как, но оно работает) Можете скайп в лс скинуть, уточню по этому вопросу момент) а то тут долго.
Заранее спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.11.2015, 00:43
Помогаю со студенческими работами здесь

Выборка данных из таблицы и суммирование этих данных
Здравствуйте, у меня затуп. Мне необходимо просуммировать значения из таблицы, однако они идут не по порядку, поэтому я создал запрос с...

Выборка данных из таблицы
Всем доброго времени суток. Объясни пожалуйста подробно: как работает select запрос в php. Вот пишу я такой код: $query =...

Перенос данных из одной таблицы в другую
Добрый день! Написал скрипт, который должен в пределах одной БД выбирать запись в 1 таблице, выбирать под неё по критерию значение из...

Перенос данных из одной таблицы в другую
Доброе утро\ День\Вечер Возникла проблема с переносом данных из двух таблиц в одну. Существует две таблицы Users и Skills. Структура...

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


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru