Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2004.02.25;
Скачать: [xml.tar.bz2];

Вниз

Перекрестный запрос   Найти похожие ветки 

 
Nikolai_S   (2004-01-30 17:19) [0]

Всем доброго времени суток.
Такая задача:
имеются три таблицы:
1. XPARAM - Название параметра по оси X
2. YPARAM - Название параметра по оси Y
3. VALUES - значение параметра в точке (X, Y).

Как составить SQL-запрос, чтобы в результате получилась бы таблица, в которой:
- количество строк = количеству строк в таблице YPARAM;
- количество столбцов = количеству столбцов в таблице XPARAM плюс 1 (1-й столбец - названия параметров из таблицы YPARAM);
- ячейки таблицы должны быть заполнены соответсвующими значениями параметров (x, y) из таблицы VALUES.

В MS Access имеется возможность создания перекрестных запросов (TRANSFORM..PIVOT), но мне нужно чтобы и в MS SQL Server работало. И потом TRANSFORM..PIVOT не выводит те строки и столбцы, которые являются пустыми.

Я делал привязывание каждого отдельного столбца через JOIN, но при большом количестве столбцов работает ужасно медленно.


 
sniknik   (2004-01-30 17:26) [1]

> но мне нужно чтобы и в MS SQL Server работало
там тоже есть подобное см. BOL на pivot table - Cross-Tab Reports, там же пример.



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

Форум: "Базы";
Текущий архив: 2004.02.25;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.44 MB
Время: 0.033 c
1-79735
h0use
2004-01-23 13:08
2004.02.25
Соответсвие индекса и названия языка в Language Info в заголовке


3-79607
Michail Dalakov
2004-02-02 17:51
2004.02.25
upWhereKeyOnly?


3-79612
Saddam
2004-01-30 18:47
2004.02.25
BDE Out of memory на 200000+ записи выборки


4-80359
Sergey20
2003-12-17 19:02
2004.02.25
API класс типа Grid


3-79587
Sava
2004-02-02 16:03
2004.02.25
Проблема со нятием флага not null на поле





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