Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Вывести значение поля в двух вариантах  (Прочитано 45829 раз)
0 Пользователей и 1 Гость смотрят эту тему.
Shouldercannon
Помогающий

ru
Offline Offline

« : 07-10-2017 14:09 » 

Есть две таблицы.
По значениям from и took таблицы request получаю ники из таблицы users
Код: (PHP)
$query = "SELECT `treq`.`uid`, `tusr1`.`nick` AS `from`, `tusr2`.`nick` AS `took`
         FROM `requests` AS `treq`
         LEFT JOIN `users` AS `tusr1` ON `tusr1`.`uid` = `treq`.`from`
                 LEFT JOIN `users` AS `tusr2` ON `tusr2`.`uid` = `treq`.`took`
                 WHERE `treq`.`uid` = '"
.$_GET['rid']."'";     
$result = mysql_query($query) or die ("ERROR: ".mysql_error());
if (mysql_num_rows($result) > 0) {
        while ($row = mysql_fetch_array($result)) {
                // Берём результаты из каждой строки
                echo $row['from'].'~'.$row['took'];
        }
}
Всё работает нормально.
Понадобилось вывести из таблицы request значение поля from как оно есть (число) и также по нему вывести ник из таблицы users
Код: (PHP)
$query = "SELECT `treq`.`uid`, `treq1`.`from` AS `id`, `tusr1`.`nick` AS `from`, `tusr2`.`nick` AS `took`
         FROM `requests` AS `treq`
                 LEFT JOIN `requests` AS `treq1` ON `treq1`.`uid` = `treq`.`from`
         LEFT JOIN `users` AS `tusr1` ON `tusr1`.`uid` = `treq`.`from`
                 LEFT JOIN `users` AS `tusr2` ON `tusr2`.`uid` = `treq`.`took`
                 WHERE `treq`.`uid` = '"
.$_GET['rid']."'";     
$result = mysql_query($query) or die ("ERROR: ".mysql_error());
if (mysql_num_rows($result) > 0) {
        while ($row = mysql_fetch_array($result)) {
                // Берём результаты из каждой строки
                echo $row['id'].'~'.$row['from'].'~'.$row['took'];
        }
}
Значение выводится, но не поля from из таблицы request.

From пытаюсь вывести как есть вот так
Код: (PHP)
`treq1`.`from` AS `id`
LEFT JOIN `requests` AS `treq1` ON `treq1`.`uid` = `treq`.`from`

* users.jpg (49.06 Кб - загружено 794 раз.)
* request.jpg (46.69 Кб - загружено 872 раз.)
Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 07-10-2017 14:52 » 

Волшебным образом идентификатор на ник не заменится. Попробуй все таки в SELECT указать желаемое.
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Shouldercannon
Помогающий

ru
Offline Offline

« Ответ #2 : 07-10-2017 17:07 » 

Решено
Код: (PHP)
$query = "SELECT `treq`.`uid`, `treq`.`from`, `tusr1`.`nick` AS `nick_from`, `tusr2`.`nick` AS `took`
         FROM `requests` AS `treq`
         LEFT JOIN `users` AS `tusr1` ON `tusr1`.`uid` = `treq`.`from`
         LEFT JOIN `users` AS `tusr2` ON `tusr2`.`uid` = `treq`.`took`
         WHERE `treq`.`uid` = '"
.$_GET['rid']."'";     
$result = mysql_query($query) or die ("ERROR: ".mysql_error());
if (mysql_num_rows($result) > 0) {
        while ($row = mysql_fetch_array($result)) {
                // Берём результаты из каждой строки
                echo $row['from'].'~'.$row['nick_from'].'~'.$row['took'];
        }
}
« Последнее редактирование: 07-10-2017 17:41 от Shouldercannon » Записан
Sla
Команда клуба

ua
Offline Offline
Пол: Мужской

WWW
« Ответ #3 : 08-10-2017 11:31 » new

Цитата
WHERE `treq`.`uid` = '".$_GET['rid']."'";
Красавчик!!!

без маскирования сразу в запрос!
Записан

Мы все учились понемногу... Чему-нибудь и как-нибудь.
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines