Хобрук: Ваш путь к мастерству в программировании

Связанный сервер со службами Analysis Services

После определения связанного сервера на SQL Server 2016 (13.0.1711.0):

EXEC master.dbo.sp_addlinkedserver @server = N'CUBELINKEDSERVER', @srvproduct=N'MSOLAP', @provider=N'MSOLAP', @datasrc=N'POWER', @catalog=N'Model'
 /* For security reasons the linked server remote logins password is changed with ######## */
EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname=N'CUBELINKEDSERVER',@useself=N'False',@locallogin=NULL,@rmtuser=NULL,@rmtpassword=NULL

и используя запрос из http://www.purplefrogsystems.com/blog/2010/09/olap-cube-documentation-in-ssrs-part-1/:

SELECT *
FROM OPENQUERY(CubeLinkedServer,
   'SELECT *
    FROM $SYSTEM.MDSCHEMA_MEASUREGROUP_DIMENSIONS') mgd
INNER JOIN OPENQUERY(CubeLinkedServer,
   'SELECT *
    FROM $SYSTEM.MDSCHEMA_MEASUREGROUPS') mg
ON mgd.XXX = mg.XXX

Я получаю сообщение об ошибке:

Сообщение 7354, уровень 16, состояние 1, строка 1 Поставщик OLE DB «MSOLAP» для связанного сервера «CubeLinkedServer» предоставил недопустимые метаданные для столбца «DIMENSION_PATH». Тип данных не поддерживается.

Как я могу это решить?


Ответы:


1

Это thread сообщает, что этот тип не поддерживается..

Проблема в том, что столбец DIMENSION_PATH имеет сложный тип. Если вы запустите запрос DMV в SSMS, вы увидите, что столбец возвращается со знаком +. Если вам особенно не нужен этот столбец, вы можете просто указать явный список столбцов, который его не включает.

SELECT a.*
FROM OPENQUERY('MSOLAP','
select
[CATALOG_NAME]
,[SCHEMA_NAME]
,[CUBE_NAME]
,[MEASUREGROUP_NAME]
,[MEASUREGROUP_CARDINALITY]
,[DIMENSION_UNIQUE_NAME]
,[DIMENSION_CARDINALITY]
,[DIMENSION_IS_VISIBLE]
,[DIMENSION_IS_FACT_DIMENSION]
--,DIMENSION_PATH
,[DIMENSION_GRANULARITY]
from
$system.MDSCHEMA_MEASUREGROUP_DIMENSIONS' ) a
20.09.2016
  • Я не думаю, что это поддерживается, в прикрепленном потоке говорится, что нужно использовать CLR 20.09.2016
  • Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

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

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..