Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  3 914

•  TDictionary Custom Sort  6 013

•  Fast Watermark Sources  5 804

•  3D Designer  8 616

•  Sik Screen Capture  6 142

•  Patch Maker  6 579

•  Айболит (remote control)  6 564

•  ListBox Drag & Drop  5 428

•  Доска для игры Реверси  95 309

•  Графические эффекты  6 776

•  Рисование по маске  5 940

•  Перетаскивание изображений  4 948

•  Canvas Drawing  5 324

•  Рисование Луны  5 051

•  Поворот изображения  4 592

•  Рисование стержней  3 249

•  Paint on Shape  2 492

•  Генератор кроссвордов  3 378

•  Головоломка Paletto  2 691

•  Теорема Монжа об окружностях  3 463

•  Пазл Numbrix  2 288

•  Заборы и коммивояжеры  2 971

•  Игра HIP  1 937

•  Игра Go (Го)  1 854

•  Симулятор лифта  2 189

•  Программа укладки плитки  1 919

•  Генератор лабиринта  2 359

•  Проверка числового ввода  2 047

•  HEX View  2 366

•  Физический маятник  1 999

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Кросс-таблица через pivot-таблицу



Автор: John Crowley

Мне нужна помощь по реализации запроса кросс-таблицы в Delphi. У кого-нибудь имеется соответствующий опыт?

Использовать pivot-таблицу должен все тот-же общий механизм (относительно к любой базе данных SQL).

Предположим, что у нас есть данные продаж в таблице с полями Store, Product, Month, Sales, и вам необходимо отображать данные по продуктам за каждый месяц. (Примем, что поле 'month' для простоты имеет значения 1..12.)

Оригинальные данные примера:

  Store         Product    Month   Sales
    #1            Toys       1      100
    #2            Toys       1       68
    #1            Toys       2      150
    #1            Books      1       75
    ...
Желаемый отчет должен выглядеть похожим на этот:
      Product         January      February    March  .....
       Toys             168          150
       Books             75         .....
Установите pivot-таблицу с именем tblPivot и 12 строками:
   pvtMonth   pvtJan  pvtFeb   pvtMar  pvtApr   ....
       1        1       0        0       0      ....
       2        0       1        0       0
       3        0       0        1       0
       4        0       0        0       1
     .....
Теперь запрос, выполненный в виде:
  select Product, January=sum(Sales*pvtJan), 
                           February=sum(Sales*pvtFeb),
                          March=sum(Sales*pvtMar), 
                          April=sum(Sales*pvtApr),...
  where Month = pvtMonth
  group by Product
даст вам информацию, опубликованную выше.

Поскольку pivot-таблица имеет только 12 строк, большинство SQL-движков сохранят результат в кэшовой памяти, так что скорость выполнения запроса весьма велика.





Похожие по теме исходники

Кроссворд

Генератор кроссвордов

Таблица совместимости продуктов питания

RSA шифрование через OpenSSL

 



Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте