Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Сообщения за день
 

Вернуться   Форум Flasher.ru > Архив Flasher.ru > Программирование > PHP

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему  
Старый 08.11.2003, 04:20
Chas вне форума Посмотреть профиль Отправить личное сообщение для Chas Посетить домашнюю страницу Chas Найти все сообщения от Chas
  № 1  
Chas
[+1 14.08.08]
[+1 20.08.08]
 
Аватар для Chas

Регистрация: Sep 2002
Адрес: simferopol
Сообщений: 981
Отправить сообщение для Chas с помощью ICQ
Question Какой-то сложный у меня запрос получается?

Народ, 3 часа ночи, что-то я тормозить начал - не могу запрос придумать.
Есть несколько таблиц, примерно одинакового содержания, в которых есть поле dPrice. Нужно сложить все данные в этом поле по всем таблицам. Что-то не придумаю(((.
__________________
~
Never trouble trouble till trouble troubles you!

Старый 08.11.2003, 12:15
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 2  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
И не придумаешь. При работе с правильно спроектированной базой такое желание не должно появляться.
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 08.11.2003, 21:26
Chas вне форума Посмотреть профиль Отправить личное сообщение для Chas Посетить домашнюю страницу Chas Найти все сообщения от Chas
  № 3  
Chas
[+1 14.08.08]
[+1 20.08.08]
 
Аватар для Chas

Регистрация: Sep 2002
Адрес: simferopol
Сообщений: 981
Отправить сообщение для Chas с помощью ICQ
Крези, это уже не вопрос организации базы. У меня есть несколько таблиц - orders_plains, orders_trains, orders_partitions - разной структуры. Но во всех них есть есть поле dPrice. Мне нужно сотставить запрос, который забрал бы из всех этих таблиц стоимость услуг соответствующий какому-то заказу (iOrderID). Конечно, можно было бы составить запрос для каждой из таблиц, и сложить все данные, но почему бы не предоставить эту задачу СУБД, а не ПХП? Только вот моего знания SQL что-то не хватает, не могу составить запрос...
__________________
~
Never trouble trouble till trouble troubles you!

Старый 09.11.2003, 00:53
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 4  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Еще раз: если подлежашие суммированию поля разнесли по разным таблицам -- это ошибка проекитирования.

Продвинутые СУБД имеют расширения SQL, позволяющие делать такие странные операции. К примеру, в MS SQL ты можешь сделать хранимую процедуру, которая не сервере выполнит три запроса, произведет суммирование и вернет результат.
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 09.11.2003, 20:48
Chas вне форума Посмотреть профиль Отправить личное сообщение для Chas Посетить домашнюю страницу Chas Найти все сообщения от Chas
  № 5  
Chas
[+1 14.08.08]
[+1 20.08.08]
 
Аватар для Chas

Регистрация: Sep 2002
Адрес: simferopol
Сообщений: 981
Отправить сообщение для Chas с помощью ICQ
Гм... с какой-то стороны ты и прав, можно запихнуть стоимость в отдельную таблицу... сенкс за мысль...
Вопрос:
где у меня ошибка в этом запросе?
SELECT dPrice from orders_propositions UNION SELECT dPrice FROM orders_transfers;
мускуль настойчиво говорит мне, что запрос неправельно составлен, хотя, насколько я помню синтаксис SQL (я не очень продвинут в запросах на объединение), все правильно написано.
__________________
~
Never trouble trouble till trouble troubles you!

Старый 09.11.2003, 21:53
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 6  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
В твоей версии MySQL тебе кем-то был обещан UNION?
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 10.11.2003, 22:41
kompadre вне форума Посмотреть профиль Отправить личное сообщение для kompadre Найти все сообщения от kompadre
  № 7  
kompadre
 
Аватар для kompadre

Регистрация: Aug 2001
Адрес: Barcelona
Сообщений: 1,277
Отправить сообщение для kompadre с помощью ICQ
Хммм ...

select sum (table1.dPrice + table2.dPrice + table3.dPrice) from table1, ...

чего то не так возвращает?

Старый 11.11.2003, 01:08
Chas вне форума Посмотреть профиль Отправить личное сообщение для Chas Посетить домашнюю страницу Chas Найти все сообщения от Chas
  № 8  
Chas
[+1 14.08.08]
[+1 20.08.08]
 
Аватар для Chas

Регистрация: Sep 2002
Адрес: simferopol
Сообщений: 981
Отправить сообщение для Chas с помощью ICQ
Мысля рульная, сейчас попробую... не... не рульная...
что пробывал -
SELECT orders_propositions.dPrice+orders_transfers.dPrice as dAllPrice FROM orders_propositions,orders_transfers WHERE orders_propositions.iOrderID=orders_transfers.iOrderID;


orders_propositions - хранится услуга - заказ путевки
orders_transfers - хранится услуга - заказ трансфера
iOrderID - ключ, соответствующий номеру заказа, причем, каждому заказу соответсвует несколько услуг - скажем, в одном заказе - две путевки и один трансфер. И для каждой услуги необходимо хранить цену - для распечатки ваучера.

Так вот, кидаю новый заказ, в нем - только путевку, без трансфера - и получаю в ответ на запрос - пустое поле((
А сточки зрения организации БД - по-моему - лучше не придумаешь. Хотя мне девятнадцать, и я не в коем случае не считаю себя супер-пупер.
__________________
~
Never trouble trouble till trouble troubles you!

Старый 11.11.2003, 01:20
kompadre вне форума Посмотреть профиль Отправить личное сообщение для kompadre Найти все сообщения от kompadre
  № 9  
kompadre
 
Аватар для kompadre

Регистрация: Aug 2001
Адрес: Barcelona
Сообщений: 1,277
Отправить сообщение для kompadre с помощью ICQ
Мля, где функция SUM в том что ты пробывал?

SELECT sum(orders_propositions.dPrice+orders_transfers.dPrice)as dAllPrice FROM orders_propositions,orders_transfers WHERE orders_propositions.iOrderID=orders_transfers.iOrderID;


А насчет организации, с каждым разом будет лучше


Последний раз редактировалось kompadre; 11.11.2003 в 01:27.
Старый 11.11.2003, 01:33
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 10  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Цитата:
Оригинал написал(а) kompadre
select sum (table1.dPrice + table2.dPrice + table3.dPrice) from table1, ...
Эта конструкция в зависимости от того, что прописано в where, либо отработает верно, либо вернет бред.

Простейший пример: в таблицаз живут значения за три разных месяца...
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Создать новую тему   Часовой пояс GMT +4, время: 00:10.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 00:10.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.