Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Вывод строки

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: Вывод строки из таблицы которой не существует в другой таблице
Sanek_OS9
Отправлено: 01 Ноября, 2013 - 16:43:26
Post Id



Гость


Покинул форум
Сообщений всего: 115
Дата рег-ции: Окт. 2012  
Откуда: Украина


Помог: 0 раз(а)




Здравствуйте, помогите составить запрос, нужно вывести одну запись из таблицы при условии что ее нет в другой таблице.
Пытался сделать это получив в запросе количество таких записей, но использовать это в WHERE не получается, хотя при выводе на экран этого количества все нормально.
PHP:
скопировать код в буфер обмена
  1. $vopros = mysql_fetch_assoc(mysql_query("SELECT `tests_vopros`.*,
  2.         (SELECT COUNT(*) FROM `tests_user` AS `count` WHERE `count`.`id_vopros` = `tests_vopros`.`id`) AS `count`
  3.         FROM `tests_vopros` WHERE `tests_vopros`.`id_tests` = '$tests[id]' ORDER BY rand() LIMIT 1")) ;
  4.  

Хотел сделать так:
PHP:
скопировать код в буфер обмена
  1. $vopros = mysql_fetch_assoc(mysql_query("SELECT `tests_vopros`.*,
  2.         (SELECT COUNT(*) FROM `tests_user` AS `count` WHERE `count`.`id_vopros` = `tests_vopros`.`id`) AS `count`
  3.         FROM `tests_vopros` WHERE `tests_vopros`.`id_tests` = '$tests[id]' AND `tests_vopros`.`count` = '0' ORDER BY rand() LIMIT 1")) ;

Но не получается.
 
 Top
Мелкий Супермодератор
Отправлено: 01 Ноября, 2013 - 23:47:31
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT /**/ FROM normal_table LEFT JOIN table_not_exists_row ON /**/ WHERE table_not_exists_row.`field_from_table` IS NULL AND /* other conditions*/


-----
PostgreSQL DBA
 
 Top
Sanek_OS9
Отправлено: 06 Ноября, 2013 - 18:51:27
Post Id



Гость


Покинул форум
Сообщений всего: 115
Дата рег-ции: Окт. 2012  
Откуда: Украина


Помог: 0 раз(а)




Мелкий пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT /**/ FROM normal_table LEFT JOIN table_not_exists_row ON /**/ WHERE table_not_exists_row.`field_from_table` IS NULL AND /* other conditions*/

Получился вот такой вот запрос
PHP:
скопировать код в буфер обмена
  1. $vopros = mysql_fetch_assoc(mysql_query("SELECT * FROM `tests_vopros` LEFT JOIN `tests_user` ON `tests_user`.`id_vopros` = `tests_vopros`.`id` WHERE `tests_user`.`id_vopros` IS NULL AND `tests_vopros`.`id_tests` = '$tests[id]' ORDER BY rand() LIMIT 1")) ;
  2.  

Все работает как планировалось но теперь не могу вывести id вопроса:

А он нужен для работы скрипта Огорчение
Пытался сделать так:
PHP:
скопировать код в буфер обмена
  1. $vopros = mysql_fetch_assoc(mysql_query("SELECT tests_vopros.* FROM `tests_vopros` LEFT JOIN `tests_user` ON `tests_user`.`id_vopros` = `tests_vopros`.`id` WHERE `tests_user`.`id_vopros` IS NULL AND `tests_vopros`.`id_tests` = '$tests[id]' ORDER BY rand() LIMIT 1")) ;
  2.  

Но потом выводит все вопросы и не обращает внимания на другую таблицу.
(Добавление)
Вроде все работает как надо, спасибо за внимание)) Хорошо
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Работа с СУБД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB