我需要在SSIS中获取SSAS多维数据集的最后处理日期并将其保存到变量中。
我已经尝试了#34;执行SQL任务":
SELECT LAST_DATA_UPDATE as LAST_DT FROM $system.mdschema_cubes
WHERE CUBE_NAME = 'CubeName'
它在MSSQL管理工作室MDX查询窗口中正常工作,但在SSIS中它表示:结果集绑定时不支持的数据类型。
然后我试过了:
WITH MEMBER [Measures].[LastProcessed] AS ASSP.GetCubeLastProcessedDate() SELECT [Measures].[LastProcessed] ON 0 FROM [CubeName]
它说' [ASSP]。[GetCubeLastProcessedDate]'功能不存在。
任何想法如何做到这一点? 谢谢
答案 0 :(得分:0)
链接服务器可能是您的最佳选择;
使用以下内容创建链接服务器,并根据需要进行更改:
EXEC master.dbo.sp_addlinkedserver
@server = N'LINKED_SERVER_OLAP_TEST', --Change to a suitable name
@srvproduct='', --Creates the productname as blank
@provider=N'MSOLAP', --Analysis Services
@datasrc=N'localhost', --Change to your datasource
@catalog=N'TESTCUBE' --Change to set the default cube
更改执行SQL任务的数据源,以确保它指向托管链接服务器的任何数据库,I.E。不使用分析服务数据源使用标准OLE DB。然后在执行SQL任务中进行以下操作(根据需要进行更改)。
SELECT *
FROM OpenQuery(LINKED_SERVER_OLAP_TEST,'SELECT LAST_DATA_UPDATE as LAST_DT FROM $system.mdschema_cubes
WHERE CUBE_NAME = ''CUBENAME''')
将变量设置为DATETIME,将结果集设置为单行。
可能有其他方法可以做到这一点,但我总是发现这种方法最直接。