2017-10-18 34 views
0

我想通过查询填写一个网格区域。但我希望此查询根据下拉列表的选择进行更改。我有三个不同的查询,我希望他们根据下拉进行交换。使用IFS()在查询语句之间切换

我试图使用IFS如下面的查询之间进行切换:

=iferror(
    IFS(B9="Value", 
       query(LOG!A4:U,"SELECT A, B, C, D, E, F, G, H, I, J, K WHERE A Is Not Null " 
       & IF(ISBLANK(B4),"", " AND K='"& LEFT(B4,7) &"'") & " " 
       & IF(D6<>"ALL", " AND N ='"& D6 &"'", "") & " " 
       & IF(E6<>"ALL", " AND Q ='"& E6 &"'", "") & " " 
       & IF(F6<>"ALL", " AND P ='"& F6 &"'", "") & " " 
       & IF(G6<>"ALL", " AND O ='"& G6 &"'", "") & " " 
       & IF(H6<>"ALL", " AND R ='"& H6 &"'", "") & " " 
       & IF(I6<>"ALL", " AND S ="& I6, "") & " " 
       & IF(ISBLANK(J6), "", " AND T ='"& LEFT(J6,7) &"'") & " " 
       & IF(ISBLANK(H9), "", " AND C >= date '" & text(H9,"yyyy-MM-dd") & "'") & " " 
       & IF(ISBLANK(I9), "", " AND D <= date '" & text(I9,"yyyy-MM-dd") & "'") & " " 
       ,-1), 
      B9 = "value 2", 
     "other query 
,"NO RESULTS") 

那么单元格的值是不是查询的价值,而这个公式只返回B9的价值。

有没有办法根据单元格的下拉选择执行不同的查询?

在此先感谢

编辑1:

=IFS(B9="WITHOUT COURSE" 
    ,FILTER(PERSONNEL!A6:J 
      ,(ISERROR(Match(PERSONNEL!A6:A,UNIQUE(filter(LOG!K4:K, VALUE(LOG!J4:J) = VALUE(RIGHT(B6,12)))),0))) 
      , (PERSONNEL!F6:F = E6) + (E6 = "ALL") 
      , (D6 = "ALL") + (PERSONNEL!D6:D = D6) 
      , (F6 = "ALL") + (PERSONNEL!G6:G = F6) 
      , (G6 = "ALL") + (PERSONNEL!E6:E = G6) 
      , (H6 = "ALL") + (PERSONNEL!I6:I = H6) 
      , (I6 = "ALL") + (PERSONNEL!H6:H = I6) 
    ) 
    ,B9="WITH COURSE" 
    ,query(LOG!A4:U,"SELECT A, B, C, D, E, F, G, H, I, J, K WHERE A Is Not Null " 
     & IF(ISBLANK(B4),"", " AND K='"& LEFT(B4,7) &"'") & " " 
     & IF(D6<>"ALL", " AND N ='"& D6 &"'", "") & " " 
     & IF(E6<>"ALL", " AND Q ='"& E6 &"'", "") & " " 
     & IF(F6<>"ALL", " AND P ='"& F6 &"'", "") & " " 
     & IF(G6<>"ALL", " AND O ='"& G6 &"'", "") & " " 
     & IF(H6<>"ALL", " AND R ='"& H6 &"'", "") & " " 
     & IF(I6<>"ALL", " AND S ="& I6, "") & " " 
     & IF(ISBLANK(J6), "", " AND T ='"& LEFT(J6,7) &"'") & " " 
     & IF(ISBLANK(H9), "", " AND C >= date '" & text(H9,"yyyy-MM-dd") & "'") & " " 
     & IF(ISBLANK(I9), "", " AND D <= date '" & text(I9,"yyyy-MM-dd") & "'") & " " 
     & IF(ISBLANK(B6), "", " AND J ='"& RIGHT(B6,12) &"'") & " " 
     & IF(ISBLANK(B7), "", " AND L ='"& RIGHT(B7,12) &"'") & " " 
     & IF(ISBLANK(B8), "", " AND M ='"& B8 &"'") & " " 
     & IF(B9 = "EXPIRES IN", " AND (DATEDIFF(now(), C)/30) >= U AND U > 0 AND (DATEDIFF(now(), C)/30) <= " &E9 & " " ,"") 
    ,-1) 
) 
+0

你错过了分号:''other query“'? –

+0

我看不到一个;在opffical文档https://support.google.com/docs/answer/7014145?hl=zh_CN中,如果我添加一个,它会自动删除 –

+0

对不起,我的意思是双引号“查询”后的单词' –

回答

0

如果删除iferror,你会看到错误消息:

错误

IFS期望所有参数位置0后成对。

我想你想设置默认值,如果公式给出了错误值“没有结果”。如果没有它,公式将无法正确使用圆括号:

=iferror(
    IFS(B9="Value", 
      "some value", 
     B9 = "value 2", 
      "other query") 
,"NO RESULTS") 
+0

谢谢mark,由于某些原因,当我使用IFS时,只有一行返回,当查询应该返回100行时。新版本 –