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

Вниз

Помогите составить хитрый запрос (Select)   Найти похожие ветки 

 
_Oleg   (2005-01-24 23:21) [0]

Есть такая таблица:

ID     |  Data  | ID1   | ID2    | Summa

Как составить запрос который был бы эквивалентен следующим запросам:

select data, id1,
count (distinct id2) as field1, sum(price) as field2
from mytable
group by data, id1

а потом на результаты 1 запроса:

select id1,
count (field1), sum(field2)
from results
group by id1


То есть следует подсчитывать кроме суммирования одного поля,
надо подсчитатать количсетво уникальных комбинаций Data + ID2


 
ЮЮ ©   (2005-01-25 03:25) [1]

В парадоксе, как его некоторые не ругают, есть такая фича, как вложенный запрос: первый запрос кладёшь в БД текстовом файле с расширением sql, например DateGrouped.sql, тогда второй запрос будет иметь вид:

SELECT id1, COUNT(field1) as Cnt, SUM(field2) as Summ
FROM "DateGrouped.sql"
GROUP by id1


 
_Oleg   (2005-01-25 07:15) [2]

К сожалению, не получилось
Пробовал в DataBase Desktop, SQL Explorer и в Delphi 5 через TQuery. Выдаёт "Opperation not applicable". Также пробовал менять двойные кавычки на одинарные, без результата :(


 
ЮЮ ©   (2005-01-25 08:19) [3]

Попробовал сам, всё работает. Запрос в SQL Explorer-e:
SELECT
 Executor, Count(Ship) Ship, Sum(Pay) as Pay
FROM
 "DateGrouped.sql"
GROUP BY
 Executor

запрос в DateGrouped.sql:

SELECT
 Accepted, Executor, Count(Ship) Ship, Sum(Pay) as Pay
FROM
 Bills
 LEFT JOIN BillDetails ON Bills.Id = BillDetails.BillId
GROUP BY
 Accepted, Executor


 
sniknik ©   (2005-01-25 08:27) [4]

> В парадоксе, как его некоторые не ругают, есть такая фича, как вложенный запрос:
это не в парадоксе, это в BDE, формат таблицы не при чем выполняет запросы движок.
и не получается (возможно) у него потому что он использует другой движок (в принципе их для парадокса не много ;о)) но гадать все одно неохота (привел бы для второго варианта))


 
_Oleg   (2005-01-25 10:05) [5]

В БДЕ администраторе показывает информацию о версии для dll - 5.2.0.2. Вроде это как последняя версия. Пробовал менять уровни таблиц для Paradox и DBASE на максимальные. Менял LocalShare. Не помогает.


 
Mutniy   (2005-01-25 10:14) [6]

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

тоесть как в MSSQL сделать временную таблицу


 
_Oleg   (2005-01-25 11:44) [7]

2Mutniy
Да, можно сохранить в промежуточную таблицу.

Но, к сожалению, мне надо - одним запросом.


 
Johnmen ©   (2005-01-25 12:11) [8]

select count(distinct cast(data as varchar(100))+cast(id2 as varchar(100))) as YourCount, sum(price) as YourSum
from mytable


 
_Oleg   (2005-01-25 14:47) [9]

2Johnmen

Спасибо, Ваш вариант вроде работает правильно

select a.ID1,  
count (distinct cast(a.data as varchar(10))+cast(a.id2 as varchar(10))) as p,
sum(a.price) as price from mytable a
group by ID1



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

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

Наверх




Память: 0.48 MB
Время: 0.026 c
14-1107249320
Ozone
2005-02-01 12:15
2005.02.20
Настройка маршрутизаторов (Cisco)


4-1104130031
KostR
2004-12-27 09:47
2005.02.20
Как при помощи Delphi передать данные с микроконторллера на ЭВМ


1-1093323585
Vilux
2004-08-24 08:59
2005.02.20
TTree и цвет текста


4-1104488042
Vaitek
2004-12-31 13:14
2005.02.20
Ярлычек


14-1107349002
Nifrit
2005-02-02 15:56
2005.02.20
проблема с Com портом