问题出在哪里:函数需要 2 参数的元组表达式。使用了元组集表达式。错误

Where is the problem in :The function expects a tuple expression for the 2 argument. A tuple set expression was used. ERROR

我正在尝试在报告的参数中设置两个值,如果我在参数@Hakemuksen tyyppi 中设置值(未知 + 其他一些值)它会给出错误 -

An error has occurred during report processing. (rsProcessingAborted) Query execution failed for dataset 'Table_1'. (rsErrorExecutingCommand) The function expects a tuple expression for the 2 argument. A tuple set expression was used.

        with
--M002
MEMBER KeskimaarainenKasittelyaikaAutomatisoiduilleKokonaisprosesseille AS (
    SUM(linkmember([Aika].[Päivämäärä].currentmember, [Aika - Päätöksen tekohetki].[Päivämäärä]),
        IIF([Measures].[Automaattisten prosessien m] = 1, [Measures].[Hakemusten Keskimääräinen Käsittelyaika], 0))
)
MEMBER KeskimaarainenKasittelyaikaManuaalisilleKokonaisprosesseille AS (
    SUM(linkmember([Aika].[Päivämäärä].currentmember, [Aika - Päätöksen tekohetki].[Päivämäärä]),
        IIF([Measures].[Automaattisten prosessien m] = 0 or IsNull([Measures].[Automaattisten prosessien m]), [Measures].[Hakemusten Keskimääräinen Käsittelyaika], 0))
)

select {
 [Measures].[Automaattinen hakemuksen tarkistus m]
,[Measures].[Automaattinen hakemuksen tarkistus r]
,[Measures].[Automaattinen ennakkoilmoitussanoma m]
,[Measures].[Automaattinen ennakkoilmoitussanoma r]
,[Measures].[Automaattinen ansiotietopyynto m]
,[Measures].[Automaattinen ansiotietopyynto r]
,[Measures].[Automaattisten lähetteiden m]
,[Measures].[Lähetteiden m]
,[Measures].[Automaattinen laakarin kasittely m]
,[Measures].[Automaattinen laakarin kasittely r]
,[Measures].[Automaattisten eläkeratkaisujen m]
,[Measures].[Ratkaistujen hakemusten m]
,[Measures].[Automaattisten päätösten m]
,[Measures].[Päätösten m]
,[Measures].[Automaattisten maksatus m]
,[Measures].[Automaattisten maksatus r]
,[Measures].[Muu tehtava noussut m]
,[Measures].[Saapuneiden hakemusten m]
,[Measures].[Automaattisten prosessien m]
,[Measures].[Automaatioaste m]
,[Measures].[Hakemusten määrä]
,KeskimaarainenKasittelyaikaAutomatisoiduilleKokonaisprosesseille
,KeskimaarainenKasittelyaikaManuaalisilleKokonaisprosesseille
} on columns,


{
EXISTS([Hakemuslaji].[Hakemuslaji].[Alintaso].members - {[Hakemuslaji].[Hakemuslaji].[Alintaso].[osa-aikaeläke], [Hakemuslaji].[Hakemuslaji].[Alintaso].[varhennettu vanhuuseläke]},
        {[Hakemuslaji].[Hakemuslaji].[työkyvyttömyyseläke],
         [Hakemuslaji].[Hakemuslaji].[kuntoutustuki],
         [Hakemuslaji].[Hakemuslaji].[osatyökyvyttömyyseläke],
         [Hakemuslaji].[Hakemuslaji].[osakuntoutustuki]}) *
{STRTOMEMBER(@TarkastelujaksonAlku) : STRTOMEMBER(@TarkastelujaksonLoppu)} *
{STRTOMEMBER("[Aika].[Kuukausi].&[" + LEFT(RIGHT(STRTOMEMBER(@TarkastelujaksonAlku).Name, 5), 2) + "]&[" + LEFT(STRTOMEMBER(@TarkastelujaksonAlku).Name, 4) + "]" ) :
STRTOMEMBER("[Aika].[Kuukausi].&[" + LEFT(RIGHT(STRTOMEMBER(@TarkastelujaksonLoppu).Name, 5), 2) + "]&[" + LEFT(STRTOMEMBER(@TarkastelujaksonLoppu).Name, 4) + "]" )}

} on rows

from [Hakemukset ja päätökset]

WHERE (
STRTOTUPLE(@KuukaudenLaskenta),
STRTOTUPLE(@HakemuksenTyyppi),
STRTOTUPLE(@ElakeratkaisunRatkaisu),
STRTOTUPLE(@ElakepaatoksenTyyppi)
)   ````

仍在处理以下问题 - 我正在重写它以查看是否有助于发现问题:

WITH
    MEMBER 
    [Measures].KeskimaarainenKasittelyaikaAutomatisoiduilleKokonaisprosesseille AS 
    (
        SUM(
          LINKMEMBER(
             [Aika].[Päivämäärä].CURRENTMEMBER
           , [Aika - Päätöksen tekohetki].[Päivämäärä]
          )
          ,IIF(
             [Measures].[Automaattisten prosessien m] = 1
           , [Measures].[Hakemusten Keskimääräinen Käsittelyaika]
           , 0  //<<<<< DO YOU DEFINITELY WANT 0?: NULL IS A LOT QUICKER IN MDX <<<<
          )
        )
    )
    MEMBER 
    [Measures].KeskimaarainenKasittelyaikaManuaalisilleKokonaisprosesseille AS 
    (
        SUM(
          LINKMEMBER(
              [Aika].[Päivämäärä].CURRENTMEMBER
            , [Aika - Päätöksen tekohetki].[Päivämäärä]
          ),
          IIF(
            [Measures].[Automaattisten prosessien m] = 0 
              OR ISNULL( [Measures].[Automaattisten prosessien m] )
          , [Measures].[Hakemusten Keskimääräinen Käsittelyaika]
          , 0  //<<<<< DO YOU DEFINITELY WANT 0?: NULL IS A LOT QUICKER IN MDX <<<<
          )
        )
    )

SELECT 
    {
       [Measures].[Automaattinen hakemuksen tarkistus m]
      ,[Measures].[Automaattinen hakemuksen tarkistus r]
      ,[Measures].[Automaattinen ennakkoilmoitussanoma m]
      ,[Measures].[Automaattinen ennakkoilmoitussanoma r]
      ,[Measures].[Automaattinen ansiotietopyynto m]
      ,[Measures].[Automaattinen ansiotietopyynto r]
      ,[Measures].[Automaattisten lähetteiden m]
      ,[Measures].[Lähetteiden m]
      ,[Measures].[Automaattinen laakarin kasittely m]
      ,[Measures].[Automaattinen laakarin kasittely r]
      ,[Measures].[Automaattisten eläkeratkaisujen m]
      ,[Measures].[Ratkaistujen hakemusten m]
      ,[Measures].[Automaattisten päätösten m]
      ,[Measures].[Päätösten m]
      ,[Measures].[Automaattisten maksatus m]
      ,[Measures].[Automaattisten maksatus r]
      ,[Measures].[Muu tehtava noussut m]
      ,[Measures].[Saapuneiden hakemusten m]
      ,[Measures].[Automaattisten prosessien m]
      ,[Measures].[Automaatioaste m]
      ,[Measures].[Hakemusten määrä]
      ,[Measures].KeskimaarainenKasittelyaikaAutomatisoiduilleKokonaisprosesseille
      ,[Measures].KeskimaarainenKasittelyaikaManuaalisilleKokonaisprosesseille
    } ON COLUMNS,
    {
    EXISTS(
       [Hakemuslaji].[Hakemuslaji].[Alintaso].MEMBERS
     - {    //<<<< THINK I'LL USE EXCEPT HERE <<<<<<<<<<<<<<<<<<<<<<<<<<<<
         [Hakemuslaji].[Hakemuslaji].[Alintaso].[osa-aikaeläke], 
         [Hakemuslaji].[Hakemuslaji].[Alintaso].[varhennettu vanhuuseläke]
       }
      ,
       {
          [Hakemuslaji].[Hakemuslaji].[työkyvyttömyyseläke],
          [Hakemuslaji].[Hakemuslaji].[kuntoutustuki],
          [Hakemuslaji].[Hakemuslaji].[osatyökyvyttömyyseläke],
          [Hakemuslaji].[Hakemuslaji].[osakuntoutustuki]
        }
     ) 

   *{ STRTOMEMBER(@TarkastelujaksonAlku) : STRTOMEMBER(@TarkastelujaksonLoppu) } //<<< I'll use STRTOSET here <<<<<<<<<<<<<<<< 
  *
    {
      STRTOMEMBER(
        "[Aika].[Kuukausi].&[" 
        + LEFT(RIGHT(STRTOMEMBER(@TarkastelujaksonAlku).Name, 5), 2) 
        + "]&[" + LEFT(STRTOMEMBER(@TarkastelujaksonAlku).Name, 4) + "]" ) 
      :
      STRTOMEMBER(
        "[Aika].[Kuukausi].&[" 
       + LEFT(RIGHT(STRTOMEMBER(@TarkastelujaksonLoppu).Name, 5), 2) 
       + "]&[" 
       + LEFT(STRTOMEMBER(@TarkastelujaksonLoppu).Name, 4) + "]" )}

    } 
    ON ROWS
FROM [Hakemukset ja päätökset]   
WHERE (
    STRTOTUPLE(@KuukaudenLaskenta),
    STRTOTUPLE(@HakemuksenTyyppi),
    STRTOTUPLE(@ElakeratkaisunRatkaisu),
    STRTOTUPLE(@ElakepaatoksenTyyppi)
    );

我要做的主要更改是将您对 STRTOMEMBER 的使用切换为 STRTOSET。此外,无论您在何处使用 "strTo.." 函数,我都会添加 CONSTRAINED 标志,这样如果字符串未解析为有效的 MDX:

,您将收到更好的错误消息
WITH
    MEMBER 
    [Measures].KeskimaarainenKasittelyaikaAutomatisoiduilleKokonaisprosesseille AS 
    (
        SUM(
          LINKMEMBER(
             [Aika].[Päivämäärä].CURRENTMEMBER
           , [Aika - Päätöksen tekohetki].[Päivämäärä]
          )
          ,IIF(
             [Measures].[Automaattisten prosessien m] = 1
           , [Measures].[Hakemusten Keskimääräinen Käsittelyaika]
           , 0  //<<<<< DO YOU DEFINITELY WANT 0?: NULL IS A LOT QUICKER IN MDX <<<<
          )
        )
    )
    MEMBER 
    [Measures].KeskimaarainenKasittelyaikaManuaalisilleKokonaisprosesseille AS 
    (
        SUM(
          LINKMEMBER(
              [Aika].[Päivämäärä].CURRENTMEMBER
            , [Aika - Päätöksen tekohetki].[Päivämäärä]
          ),
          IIF(
            [Measures].[Automaattisten prosessien m] = 0 
              OR ISNULL( [Measures].[Automaattisten prosessien m] )
          , [Measures].[Hakemusten Keskimääräinen Käsittelyaika]
          , 0  //<<<<< DO YOU DEFINITELY WANT 0?: NULL IS A LOT QUICKER IN MDX <<<<
          )
        )
    )

SELECT 
    {
       [Measures].[Automaattinen hakemuksen tarkistus m]
      ,[Measures].[Automaattinen hakemuksen tarkistus r]
      ,[Measures].[Automaattinen ennakkoilmoitussanoma m]
      ,[Measures].[Automaattinen ennakkoilmoitussanoma r]
      ,[Measures].[Automaattinen ansiotietopyynto m]
      ,[Measures].[Automaattinen ansiotietopyynto r]
      ,[Measures].[Automaattisten lähetteiden m]
      ,[Measures].[Lähetteiden m]
      ,[Measures].[Automaattinen laakarin kasittely m]
      ,[Measures].[Automaattinen laakarin kasittely r]
      ,[Measures].[Automaattisten eläkeratkaisujen m]
      ,[Measures].[Ratkaistujen hakemusten m]
      ,[Measures].[Automaattisten päätösten m]
      ,[Measures].[Päätösten m]
      ,[Measures].[Automaattisten maksatus m]
      ,[Measures].[Automaattisten maksatus r]
      ,[Measures].[Muu tehtava noussut m]
      ,[Measures].[Saapuneiden hakemusten m]
      ,[Measures].[Automaattisten prosessien m]
      ,[Measures].[Automaatioaste m]
      ,[Measures].[Hakemusten määrä]
      ,[Measures].KeskimaarainenKasittelyaikaAutomatisoiduilleKokonaisprosesseille
      ,[Measures].KeskimaarainenKasittelyaikaManuaalisilleKokonaisprosesseille
    } ON COLUMNS,
    EXISTS(
       EXCEPT( //<<<< ALTERNATIVE MORE READABLE <<<<<<<<<<<<<<<<<<<<<<<<<<<<
         {[Hakemuslaji].[Hakemuslaji].[Alintaso].MEMBERS}
        ,{    
           [Hakemuslaji].[Hakemuslaji].[Alintaso].[osa-aikaeläke], 
           [Hakemuslaji].[Hakemuslaji].[Alintaso].[varhennettu vanhuuseläke]
         }
      ,{
          [Hakemuslaji].[Hakemuslaji].[työkyvyttömyyseläke],
          [Hakemuslaji].[Hakemuslaji].[kuntoutustuki],
          [Hakemuslaji].[Hakemuslaji].[osatyökyvyttömyyseläke],
          [Hakemuslaji].[Hakemuslaji].[osakuntoutustuki]
        }
     ) 

   *{ STRTOSET( 
         @TarkastelujaksonAlku + ":" + @TarkastelujaksonLoppu
       , CONSTRAINED 
      ) } //<<< now using STRTOSET <<<<<<<<<<<<<<<< 
   *{
      STRTOSET(
        "[Aika].[Kuukausi].&[" 
        + LEFT(RIGHT(STRTOMEMBER(@TarkastelujaksonAlku).Name, 5), 2) 
        + "]&[" + LEFT(STRTOMEMBER(@TarkastelujaksonAlku).Name, 4) + "]" ) 
        + ":"
        + "[Aika].[Kuukausi].&[" 
        + LEFT(RIGHT(STRTOMEMBER(@TarkastelujaksonLoppu).Name, 5), 2) 
        + "]&[" 
        + LEFT(STRTOMEMBER(@TarkastelujaksonLoppu).Name, 4) + "]" 
       ,CONSTRAINED
       ) //<<< now using STRTOSET  <<<<<<<<<<<<<<<< 
     }

    ON ROWS
FROM [Hakemukset ja päätökset]   
WHERE 
   STRTOSET(
    @KuukaudenLaskenta + "," +
    @HakemuksenTyyppi + "," +
    @ElakeratkaisunRatkaisu + "," +
    @ElakepaatoksenTyyppi
    );