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

Вниз

SQL запрос   Найти похожие ветки 

 
NILLO   (2005-11-28 13:19) [0]

Здравствуйте. У меня возникла следующая проблема: Пишу прогу на Delphi 7 используя компонент Query. Делаю SQL запрос к файлам БД (Paradox), а именно CashPay.db и CashSail.db. В первой таблице содержатся следующие поля “CashNumber” (числовой), “ZNumber”(числовой), “ChackNumber”(числовой), “PayedRub” (денежный). Во второй “CashNumber” (числовой), “ZNumber”(числовой), “ChackNumber”(числовой), Date (дата). Использую следующий запрос:
SELECT S.CashNumber, S."Date", COUNT (P.PayedRub)
FROM CashSail S, CashPay P
WHERE (P.ZNumber = S.Znumber)
AND (P.CheckNumber = S.CheckNumber)
AND (S."Date" BETWEEN ‘18.10.2005’ AND ‘19.10.2005’)
GROUP BY S.CashNumber, S."Date";
Этот запрос выводит следующие значения:
Date              | Count (PlayedRub)
18.10.2005     256
19.10.2005    122
Это все работает, все хорошо. Суть проблемы в том что необходимо добавить еще несколько не существующих полей. В которых бы отбирались данные из поля PlayedRub. В первое поле выодилось число записей у которых значение PlayedRub < 50, во второе от 50 до 100 и т.д. Что то вроде этого:
SELECT S.CashNumber, S."Date", COUNT (P.PayedRub), COUNT (P.PayedRub < 50),
FROM CashSail S, CashPay P…
И получился уже такой вид:
Date            | Count (PlayedRub< 50) | Count (PlayedRub>50 но <100) | Count (PlayedRub)
18.10.2005 |156     | 100              | 256
19.10.2005 | 11     | 111              | 122
Если это возможно, то подскажите как это реализовать.


 
Sergey13 ©   (2005-11-28 13:28) [1]

Попробуй примерно так
SELECT S.CashNumber, S."Date", COUNT (P.PayedRub)
FROM CashSail S, CashPay P, CashPay P1, CashPay P2
WHERE (P.ZNumber = S.Znumber)
AND (P1.ZNumber = S.Znumber)
AND (P2.ZNumber = S.Znumber)
AND P.PlayedRub< 50
AND P1.PlayedRub BETWEEN 50 AND 100
AND P2.PlayedRub>100
AND (P.CheckNumber = S.CheckNumber)
AND (P1.CheckNumber = S.CheckNumber)
AND (P2.CheckNumber = S.CheckNumber)
AND (S."Date" BETWEEN ‘18.10.2005’ AND ‘19.10.2005’)
GROUP BY S.CashNumber, S."Date";


 
evvcom ©   (2005-11-28 14:17) [2]


> Sergey13 ©   (28.11.05 13:28) [1]

Низя так джойнить. Допустим P.PlayedRub< 50 удовлетворяют 5 записей, а AND P1.PlayedRub BETWEEN 50 AND 100 - 10 записей. В результате джойна получим 50 записей.

> NILLO

Навскидку вижу 3 способа, но с LocalSQL ни один не прокатит:
1. самый оптимальный:
select
 Sum(case when PlayedRub<50 then 1 else 0) as interval1,
 Sum(case when PlayedRub BETWEEN 50 AND 100 then 1 else 0) as interval2
from ...

2.
select sum(i1) as i1, sum(i2) as i2
from (
 select count(*) as i1, 0 as i2 from ... where PlayedRub<50
 union
 select 0 as i1, count(*) as i2 from ... where PlayedRub BETWEEN 50 AND 100)

3.
select t1."Date", t1.i1, t2.i2
from (select "Date", count(*) as i1 from ... where PlayedRub<50 group by "Date") t1
 full join
   (select "Date", count(*) as i2 from ... where PlayedRub BETWEEN 50 AND 100 group by "Date") t2


 
NILLO   (2005-11-28 14:25) [3]

Теоретически это должно работать, я согласен, но на практике прога вешается и причем вешается на смерть. Я думаю, что это из-за большого объема базы там порядка 50 000 записей.


 
Sergey13 ©   (2005-11-28 14:37) [4]

2[2] evvcom ©   (28.11.05 14:17)
Согласен. Поторопился я.


 
NILLO   (2005-11-28 14:51) [5]

Ну как, мне уже можно отчаиваться и впадать в панику?


 
msguns ©   (2005-11-28 15:25) [6]

Можно получить вот такой НД:

Date          |  Count < 50 | Count >50 но <100 | Count >=100
18.10.2005  |156            | 0                         | 0
19.10.2005  | 11             | 0                         | 0
18.10.2005  |0               | 100                      | 0
19.10.2005  |0               | 111                      | 0
18.10.2005  |0               | 0                         | 256
19.10.2005  |0               | 0                         | 122

Через Cast + Group By + Union


 
mr.il ©   (2005-11-28 15:36) [7]

А есче перейти на клиент-сервер и там в СП делать че хош.


 
NILLO   (2005-11-28 15:46) [8]

Самое лучшее к чему я пришел это испольование подзапроса.


 
evvcom ©   (2005-11-28 15:52) [9]


> msguns ©   (28.11.05 15:25) [6]

А Cast тут где? Такой набор получается из [2] 2. внутренних селектов объединенных union. Остается сделать еще один select из этого результата и получится, что надо.
Могу предложить:
1. То что уже предложил > mr.il ©   (28.11.05 15:36) [7]
2. Добавить туда еще order by "Date" и перегнать в TClientDataSet, выполнив группировку уже на клиенте.
3. Создать дополнительную таблицу. В нее скидывать INSERT-ом этот SELECT. Потом результирующий select из этой промежуточной таблицы.


 
evvcom ©   (2005-11-28 16:03) [10]

Да! Есть еще способ. Смотри "Local SQL VIEWs". То, что в [2] 2. в скобках: select ... union select ... загоняешь в MyView.sql и делаешь обычный select ... from "MyView.sql" group by ... order by ...
О-ля-ля! (с) "Назад в будущее"


 
NILLO   (2005-11-28 16:23) [11]

Клиент-сервер сразу отпадает программа должна быть автономной (без привязки к чему либо) и мобильной работать на любом компе без дополнительных приложений.


 
evvcom ©   (2005-11-28 16:43) [12]


> и мобильной работать на любом компе без дополнительных приложений.

Насколько я понял, парадокс ты используешь? Насколько мне известно с парадоксом без BDE даже ADO не работает. Т.е. без установки BDE выходит не обойтись.
Какие компоненты доступа используешь?


 
NILLO   (2005-11-29 11:17) [13]

Использую Query. А обхожусь без BDE, указывая путь к базе в свойство
"DatabaseName".



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

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

Наверх




Память: 0.48 MB
Время: 0.013 c
2-1133393751
Юрий Ж.
2005-12-01 02:35
2005.12.18
[?]TClientSocket &amp; TServerSocket


6-1126018861
Ландграф Павел
2005-09-06 19:01
2005.12.18
Сервер на XP


14-1132938352
Fl@sh
2005-11-25 20:05
2005.12.18
Приглашение в Украину!!


2-1133224859
nickmas
2005-11-29 03:40
2005.12.18
Проблема с процедурой OnDrawCell


1-1132911148
_dimka
2005-11-25 12:32
2005.12.18
закрытие MDI Форм





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский