Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Интересная задачка, Простые таблицы, интересная заморочка 
:(
    Опции темы
initmax
Дата 15.6.2012, 10:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 165
Регистрация: 24.7.2009

Репутация: нет
Всего: нет



Дано две простых таблицы

Код

shop
1) ID - auto increment - "int"
2) Name - "varchar"

goods
1) ID - auto increment - "int"
2) ID_shop - "int"
3) Profit - "int"


В таблице "shop" и ID и Name всегда уникальны. В таблице "goods" поля могут повторяться
Требуется составить запрос который покажет сумму по каждому Shop.Name.

Первое что приходит на ум:

Код

SELECT  Name, SUM(Profit) AS result_mount 
FROM goods
JOIN (SELECT * FROM shop s)
res ON res.ID = goods.ID_shop GROUP BY Name;


Всё отрабатывает корректно, но учёные мужи утверждают, что при таком запросе на некоторых входных данных иногда возникают ошибки.

1) Надо вычислить эти самые хитрые входные данные
2) Подправить запрос

У кого какие идеи? в какую сторону копать? 





PM MAIL   Вверх
Akina
Дата 15.6.2012, 10:40 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 45
Всего: 454



Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
Интересная задачка.

Ни хрена не интересная. Простая как две копейки.

Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
В таблице "shop" и ID и Name всегда уникальны.

По отдельности или парой?

Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
Первое что приходит на ум

Бредятина. Последствия процедурного мышления, перенесённого на SQL.

Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
Всё отрабатывает корректно

На какой СУБД?

Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
Подправить запрос

Написать заново. С нуля. Предварительно почитав хоть что-нибудь про SQL.

Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
Надо вычислить эти самые хитрые входные данные

Магазины, по которым нет товаров в таблице goods, не будут присутствовать в выходном наборе, например.
Если в каких-то записях не проставлен Profit - тоже возможно счастьице...

Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
Подправить запрос

Ооо... это самостоятельно.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Zloxa
Дата 15.6.2012, 11:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 53
Всего: 161



Цитата(initmax @  15.6.2012,  11:01 Найти цитируемый пост)
на некоторых входных данных иногда возникают ошибки.

Ошибки какого характера?
Я так полагаю, результат этого запроса не соответствует каким-то бизнесс требованиям.
Что заставляет вас полагать, что нам эти требования известны?



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
initmax
Дата 15.6.2012, 11:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 165
Регистрация: 24.7.2009

Репутация: нет
Всего: нет



Цитата

Я так полагаю, результат этого запроса не соответствует каким-то бизнесс требованиям.
Что заставляет вас полагать, что нам эти требования известны?


спасибо за ответ, я просто не полностью знал условие задачи. 
Требования не были чётко сформулированы, т.е. по принципу "догадайся мол сам" 
когда начал прояснять их то оказалось что надо отобразить все магазины, даже те у которых товаров 0. Теперь всё ясно. 



Это сообщение отредактировал(а) initmax - 15.6.2012, 11:45
PM MAIL   Вверх
Zloxa
Дата 15.6.2012, 12:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 53
Всего: 161



Цитата(initmax @  15.6.2012,  12:43 Найти цитируемый пост)
 Теперь всё ясно. 

Т.е. вопрос снят, про left join вы в курсе?


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
initmax
Дата 15.6.2012, 13:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 165
Регистрация: 24.7.2009

Репутация: нет
Всего: нет



Да, разумеется, всем спасибо.

З.Ы.
Не люблю загадок с не полным условием ... 


PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




[ Время генерации скрипта: 0.2372 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.