我需要在SSIS中获取SSAS多维数据集的上次处理日期并将其保存到变量中。
我尝试了"执行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]。[GetCubeLastProcessingDate]' 函数不存在。
任何想法如何做到这一点?谢谢
链接服务器可能是您的最佳选择;
使用以下命令创建链接服务器,并根据需要进行更改:
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 任务的数据源,以确保它指向托管链接服务器的任何数据库,即不使用分析服务数据源使用标准 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,将结果集设置为单行。
可能还有其他方法可以做到这一点,但是我一直觉得这种方法最直接。