Кросс-таблица через pivot-таблицуDelphi , Базы данных , ТаблицыКросс-таблица через 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-движков сохранят результат в кэшовой памяти, так что скорость выполнения запроса весьма велика. В статье рассматривается реализация кросс-таблицы с помощью pivot-таблицы в Delphi, предназначенная для отображения данных продаж по продуктам за каждый месяц. Комментарии и вопросыПолучайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Telegram-канал delphi_kansoftware и будьте в курсе последних тенденций в разработке под Linux, Windows, Android и iOS Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.
|
||||
©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007 |