在 SSIS 中获取上次多维数据集处理日期



我需要在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,将结果集设置为单行。

可能还有其他方法可以做到这一点,但是我一直觉得这种方法最直接。

最新更新