Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.07.17;
Скачать: CL | DM;

Вниз

Люди HELP плиз!!! Проблема с вычислением ТОТАЛ-а...   Найти похожие ветки 

 
DBDev   (2003-07-02 09:52) [0]

Запрос типа :
SELECT Поле1, Поле2, dbo.Функция(Поле3) AS Поле4 FROM Таблица

Надо сосчитать Сумму по полю 4.
Используемая компонента TADOQuery.

Вопрос1: В TADOQuery:OnCalcFields Делаю
Знач = Знач + Поле4;

В результате получаю искомое т.е. сумму по полю 4, НО почемы-то на всех компах кроме моего это значение вычисляется ОШИБОЧНО. НА МОЕМ ВСЕ СХОДИТСЯ.

Посему:

Вопрос2: Может что-нить связанное с нехватанием каких-то патчей для работы программы на компе где НЕТ Дельфей/Билдера?

И:

Вопрос 3: А как посчитать требуемое значение в самом запросе?

Вопрос 4: и насколько это будет правильней с точки зрения производительности?


 
Johnmen   (2003-07-02 09:59) [1]

1. Что есть Знач ?
2. Нет.
3. ..., SUM(dbo.Функция(Поле3)) AS СуммаПоПоле4 ...
4. намного


 
DBDev   (2003-07-02 10:04) [2]

2 JohnMen:

1. double Знач;
Знач = Знач + Поле4->AsFloat;

3.
В результате во вьюшке вылетает ошибка:

Coulumn Поле3 is invalid in the select clause because it is not contained in an agregate function and there is no GROUP BY clause.


 
Zacho   (2003-07-02 10:08) [3]


> DBDev (02.07.03 10:04)

Почитай что-нибудь по SQL, агрегатным функциям и GROUP BY.
И, не совсем понятно, что именно тебе надо получить в результате. Подозреваю, что тебе нужен отдельный запрос типа SELECT SUM(dbo.Функция(Поле3)) AS Сумма_Поле4 FROM Таблица



 
DBDev   (2003-07-02 10:11) [4]

2 Zacho: Таких тоталов мне считать 8 штук. Полагаю, что выполнять 8 дочерних запросов - не правильно!


 
Zacho   (2003-07-02 10:14) [5]


> DBDev (02.07.03 10:11)

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


 
DBDev   (2003-07-02 10:24) [6]

CREATE VIEW dbo.BudjetsMain
AS
SELECT BudjetID, ClientID, dbo.GetClient(ClientID) AS Client, dbo.GetResp(RespID) AS Responsible, DateFrom, DateTo, dbo.GetPrixod(BudjetID) AS Prixod,
dbo.GetPolucheno(BudjetID) AS Polucheno, dbo.GetPrixod(BudjetID) - dbo.GetPolucheno(BudjetID) AS Debet, dbo.GetRasxod(BudjetID) AS Rasxod,
dbo.GetOplacheno(BudjetID) AS Oplacheno, dbo.GetRasxod(BudjetID) - dbo.GetOplacheno(BudjetID) AS Kredit, dbo.GetPrixod(BudjetID)
- dbo.GetRasxod(BudjetID) AS Delta, dbo.GetPolucheno(BudjetID) - dbo.GetOplacheno(BudjetID) AS DeltaFact, Notes, HiddenNotes,
BudjetPeriodID, RespID, Number
FROM dbo.Budjets


Надо получить итоговые суммы по полям Prixod, Rashod, Polucheno, Potracheno, Kreditorka, Debitorka, Delta.


 
Anatoly Podgoretsky   (2003-07-02 10:35) [7]

В принципе неверно использовать OnCalcFields, поскольку вычисления производятся
1. многократно, поулчается плавающий, нарастающий итог
2. вычисления производятся не по всей таблице, а по мере необходимости



 
Zacho   (2003-07-02 10:41) [8]


> DBDev (02.07.03 10:24)

Все равно не понятно, как именно должен выглядеть резалтсет. Но вот простой пример запроса с агрегированием:
SELECT FIELD_1, FIELD_2, SUM(FIELD_3), SUM(FIELD_4)
FROM TABLE
GROUP BY FIELD_1,FIELD_2
В результате получишь суммы FILED_3 и FIELD_4 для тех групп строк, у которых одинаковые значения FIELD_1 и FIELD_2


 
DBDev   (2003-07-02 10:45) [9]

Дык все дело в том, что альтернативы посчитать сумму по итогам вычисляемого столбца на основе Функции никакой, в моем случае
В выражении:

Func(Поле1) AS Поле2, SUM(Func(Поле1)) As ПОЛЕ3

Получается Поле2 = ПОЛЕ3

Или я что-то делаю не так???


 
DBDev   (2003-07-02 10:47) [10]

2 Zacho:
А если FIELD_1 - это PRIMARY KEY, Тогда см сообщением выше!


 
Zacho   (2003-07-02 10:52) [11]


> DBDev (02.07.03 10:45)

Этого вообще не понял.

> DBDev (02.07.03 10:47)

Какие тебе нужны критерии агрегирования ? Т.е. сумму по каким записям тебе нужно посчитать ?


 
Johnmen   (2003-07-02 10:53) [12]

Теперь понятно, что хочешь.
Какая версия MSSQL ?


 
DBDev   (2003-07-02 10:56) [13]

2 Johnmen: 2000


 
DBDev   (2003-07-02 10:59) [14]

2 Zacho: У меня есть вьюшка (приведена выше).
Суммы надо считать по всем ее значениям. Соответственно из софта задается определенная выборка по вьюшке и каждом случае считается сумма по всем строкам результата. Фактически это сумма сумм, вычисляемых функциями из других таблиц базы.


 
Johnmen   (2003-07-02 11:15) [15]

Точно уже не помню (сам посмотри док-ю по диалекту SQL MSSQL2000), но вроде бы можно группировать так
GROUP BY ...,Func(Поле1),...


 
DBDev   (2003-07-02 11:28) [16]

2 JohnMen;
Нетушки, он хочет чтобы я включил все поля которые выбираю SELECT-ом в GROUP BY. В моем случае это:

ClientID, RespID, BudjetID, DateFrom, DateTo, BudjetPeriodID, Number


 
Anatoly Podgoretsky   (2003-07-02 11:37) [17]

DBDev (02.07.03 11:28)
Он правильно хочет, для аггрегирования должна выдаваться одна строка.


 
Johnmen   (2003-07-02 11:50) [18]

>DBDev (02.07.03 11:28)
>...он хочет чтобы я включил все поля которые выбираю SELECT-ом ...

А что в этом незаконного ?
Может ты не совсем понимаешь, что такое ГРУППИРОВКА ?



Страницы: 1 вся ветка

Текущий архив: 2003.07.17;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.009 c
14-55803
cyborg
2003-07-01 00:46
2003.07.17
Осторожно, идиотские инструкции!


6-55690
Oleg_delphin
2003-05-12 14:55
2003.07.17
Отправка на FTP


14-55740
Ajax
2003-07-01 09:22
2003.07.17
НТВ+


1-55599
tm
2003-07-03 12:40
2003.07.17
Исчезает из формы StatusBar, при разв. окна и обрат. опер.


1-55654
CAHbI4
2003-07-04 13:49
2003.07.17
Поиск в TListView





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский