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
Форумы портала PHP.SU :: Версия для печати :: Помогите написать запрос
Форумы портала PHP.SU » » Вопросы новичков » Помогите написать запрос

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

1. amf1k - 22 Апреля, 2015 - 09:39:34 - перейти к сообщению
есть таблица в БД "kino"
2 поля: название фильма "title" и актер играющий роль "actor"
нужно выбрать все фильмы где играют роль определенные 2 актера вместе
вот мой запрос, он конечно не работает(
SELECT `title` FROM `kino` WHERE `actor`="Вася" AND `actor`="Петя"
помогите исправить запрос?
2. tato - 22 Апреля, 2015 - 10:06:41 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. SELECT title, count(*) t FROM kino WHERE actor = 'Vasya' OR actor = 'Petia' GROUP BY title HAVING t > 1
  3.  


это не сработает если есть дубликаты записей, вроде таких
Фильм1, Вася
Фильм1, Вася
Фильм1, Петя
Фильм2, Вася
Фильм2, Петя
3. file.shreder - 23 Апреля, 2015 - 19:47:31 - перейти к сообщению
А че не работает? Покажи весь запрос целиком в коде! Или это вопрос из разряда философских?
4. LIME - 23 Апреля, 2015 - 21:04:26 - перейти к сообщению
amf1k у тебя правильный запрос
проблема наверное в другом
(Добавление)
tato дурилка))
5. tato - 24 Апреля, 2015 - 06:24:54 - перейти к сообщению
[quote=LIME][/quote]
С чего это? Как Я понял записи в таком виде
Фильм1 Вася
Фильм2 Вася
Фильм1 Петя

И как запрос опа выберет Фильм1?
(Добавление)
И вообще как поле может иметь сразу два значения? Запрос опа в принципе не корректен
6. amf1k - 24 Апреля, 2015 - 18:05:09 - перейти к сообщению
tato пишет:
LIME пишет:

С чего это? Как Я понял записи в таком виде
Фильм1 Вася
Фильм2 Вася
Фильм1 Петя

И как запрос опа выберет Фильм1?
(Добавление)
И вообще как поле может иметь сразу два значения? Запрос опа в принципе не корректен


Вот 3 таблицы:
1-я таблица фильмы
id,title (название фильма)
2-я таблица актеры
id,name (имя актера)
3-я таблица роли (то есть, фильм и актеры. которые играют роль в этом фильме)
title (название фильма), actor (актер, который играет роль в этом фильме)
Вопрос тот же?
7. amf1k - 24 Апреля, 2015 - 20:19:51 - перейти к сообщению
[quote=tato][/quote]

Пример:

id - 1
movie - Злодей
actor - Даша

id - 2
movie - Злодей
actor - Вася

id - 3
movie - Злодей (Это уже другой фильм "Злодей")
actor - Вася

id - 4
movie - Злодей (Это уже другой фильм "Злодей")
actor - Катя

id - 5
movie - Санта Барбара
actor - Даша

id - 6
movie - Санта Барбара
actor - Вася

id - 7
movie - Злодей
actor - Петя

id - 8
movie - Герой
actor - Петя

id - 9
movie - Герой
actor - Вася

итог 4 фильма:
Фильм "Злодей": актеры - Даша,Вася,Петя
Фильм "Злодей другой фильм": актеры - Вася,Катя
Фильм "Санта Барбара": актеры - Даша,Вася
Фильм "Герой": актеры - Петя,Вася

например нужно вытащить фильмы Васи и Пети, где они играли роль вмете
получаем 2 фильма: "Злодей","Герой"
8. exlant - 24 Апреля, 2015 - 22:01:19 - перейти к сообщению
Вам нужно что то типо такого сделать:
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. SELECT m.id, m.title, r.actor FROM movies m
  3. INNER JOIN role r ON m.title = r.title
  4. WHERE r.actor = 'Петя' OR r.actor = 'Вася'
  5.  
  6.  


хотя структура базы данных у вас ужасная, и не совсем понятно, что нужно сделать...
9. amf1k - 24 Апреля, 2015 - 22:20:36 - перейти к сообщению
[quote=exlant][/quote]
да структура самая понятная какая может быть)
ваш запрос выводить все фильмы васи и пети в дублированном виде по несколько раз, так что он не верный!
10. exlant - 25 Апреля, 2015 - 01:08:46 - перейти к сообщению
я не говорю, что она не понятная, я говорю, что она плохая!
Правильней было бы сделать как то так:
1ая таблица - kino: id, title
2ая таблица - actor: id, name
3ья таблиц - roli: id, kino_id, actor_id

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

И ваш вопрос можно решить используя одну-последнюю таблицу, непонятно зачем было нам приводить две первых!

Вот возможные решения:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT title FROM roli
  2. WHERE title IN (SELECT title FROM roli WHERE actor = 'Петя') AND actor = 'Вася'
  3. GROUP BY title

или же
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT title, SUM(actor = 'Петя') AS a_1, SUM(actor = 'Вася') AS a_2
  2. FROM roli
  3. GROUP BY title HAVING a_1>0 AND a_2>0


Скорей всего можно решить эту задачу более элегантно!
11. amf1k - 25 Апреля, 2015 - 02:39:16 - перейти к сообщению
exlant пишет:
я не говорю, что она не понятная, я говорю, что она плохая!
Правильней было бы сделать как то так:
1-я таблица - kino: id, title
2-я таблица - actor: id, name
3-я таблиц - roli: id, kino_id, actor_id

а у меня как? вы написали такую же структуру таблиц как и у меня, где разница???
разница в том, связывать проще будет название фильма и имя актера, чем id фильма и id актера, ведь для этого не нужно искать под каким id фильм и под каким id актер, ведь я прав?)

exlant пишет:
А у вас все в третьей таблице, есть и название фильмов, и актеров, и вообще не понятно, зачем первая и вторая тогда таблицы...

1-я таблица - там хранится вся инфа о фильме
2-я таблица - там хранится все инфа об актере
3-я таблица будет связывать фильм и актеров, которые играют роль в этом фильме

Вот мой вариант запроса:
PHP:
скопировать код в буфер обмена
  1.  
  2. SELECT `movie` FROM `roles` WHERE `movie` IN(
  3.     SELECT `movie` FROM `roles` WHERE `actor`="Вася"
  4. ) AND `actor`="Петя"
  5.  
12. exlant - 25 Апреля, 2015 - 02:54:43 - перейти к сообщению
Цитата:
а у меня как? вы написали такую же структуру таблиц как и у меня, где разница???
разница в том, связывать проще будет название фильма и имя актера, чем id фильма и id актера, ведь для этого не нужно искать под каким id фильм и под каким id актер, ведь я прав?)

я написал структуру базы данных, а не таблиц!
и в моем случаи есть связь, и необходимость в первых двух таблицах, в вашей же ее нет!
вот почитайте http://www[dot]site-do[dot]ru/db/db3.php , здесь очень кратко о том, что я говорю!

Цитата:
Вот мой вариант запроса:

ну так, это мой первый вариант, переделанный...
13. DeepVarvar - 25 Апреля, 2015 - 08:47:24 - перейти к сообщению
Посоны, почему никто до сих пор не отправил ТСа читать про нормальные формы?
Вместо этого все тут лепят велосипеды.
А ТС думает что, вот он какой крутой, сложная задача у него, даже для сильных.

 

Powered by ExBB FM 1.0 RC1