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 :: Запрос SQL.

 PHP.SU

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


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

> Описание: запрос SQL.
Jewish-Man
Отправлено: 27 Сентября, 2011 - 16:20:35
Post Id


Новичок


Покинул форум
Сообщений всего: 13
Дата рег-ции: Авг. 2011  


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




Здравствуйте.
Есть таблица родителей и детей.
ID | Name | ParentID |
1 | Paul | 5 |
2 | Bob | 3 |
3 | Larry | 1 |
4 | John | 3 |
5 | George | 4 |
6 | Steven | 6 |
Как вычислить всех детей, у которых родитель Bob.
И как вычислить родителя, у которого ребенок George.
Заранее благодарен.
 
 Top
illy
Отправлено: 27 Сентября, 2011 - 16:46:34
Post Id



Участник


Покинул форум
Сообщений всего: 1117
Дата рег-ции: Июль 2011  
Откуда: от верблюда)


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




а где имена детей? или вместо них Id? не понял


-----
Всё гениальное - просто
И ещё проще, если ты - индиго
 
 Top
Мелкий Супермодератор
Отправлено: 27 Сентября, 2011 - 16:50:44
Post Id



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


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


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




illy, та дерево это генеалогическое.

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `tbl` WHERE `ParentID` IN (SELECT `ID` FROM `tbl` WHERE `Name`='желаемое имя отца')


-----
PostgreSQL DBA
 
 Top
Jewish-Man
Отправлено: 27 Сентября, 2011 - 17:21:58
Post Id


Новичок


Покинул форум
Сообщений всего: 13
Дата рег-ции: Авг. 2011  


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




Мелкий пишет:
illy, та дерево это генеалогическое.

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `tbl` WHERE `ParentID` IN (SELECT `ID` FROM `tbl` WHERE `Name`='желаемое имя отца')


Спасибо.
Я вот только думаю, как это через JOIN сделать. Подмигивание
подзапросы не очень зачастую подходят Улыбка

(Отредактировано автором: 27 Сентября, 2011 - 17:23:00)

 
 Top
White
Отправлено: 27 Сентября, 2011 - 17:29:54
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 830
Дата рег-ции: Июнь 2011  
Откуда: Днепропетровск


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




Jewish-Man пишет:
как это через JOIN сделать

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT `b`.* FROM `tbl` AS `a`
  2. LEFT JOIN `tbl` AS `b` ON `a`.`ID`=`b`.`ParentID`
  3. WHERE `a`.`Name`='желаемое имя отца')

только зачем это надо, не понятно, подзапрос в данном случае - оптимальный вариант.


-----
if(time()>1356048000) die();
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB