【问题标题】:Using Select statement within a IIF function在 IIF 函数中使用 Select 语句
【发布时间】:2020-10-16 22:00:18
【问题描述】:

如果列中没有“位”,并且如果有“位”,我想获取最后 20 条记录,我想获取该记录之后的记录。在我的示例中是“评论”列中的“干船坞”字符串。 这是我的 SQL:

SELECT TOP 20 
    [Date], 
    [Lift ID]
FROM [Input Data$]
WHERE [Vessel name]='" + shipName + "' 
    AND [Lift ID] >= Iif(
                            (
                                SELECT max([Lift ID]) 
                                FROM [Input Data$] 
                                WHERE [Vessel name]='" + shipName + "' 
                                    AND [Comments] LIKE '%dry dock%'
                            ) >=1;
                            (
                                SELECT max([Lift ID]) 
                                FROM [Input Data$] 
                                WHERE [Vessel name]='" + shipName + "' 
                                    AND [Comments] LIKE '%dry dock%'
                            );
                            1
                        )
ORDER BY [Date] DESC

我收到 VBA Run-time '-2147217900 (80040e14)' 错误消息“[Microsoft][ODBC Excel Driver] Syntax error in query expression ...”

为什么会出现这个错误?

【问题讨论】:

  • 我建议您使用 LinqPad 编写测试查询,然后在 LinqPad 中显示正确结果后将其粘贴到您的程序中:linqpad.net
  • 样本数据、所需结果和适当的数据库标签都会有所帮助。

标签: sql excel subquery iif


【解决方案1】:

使您的嵌套查询成为单独的查询LikeDryDock

    SELECT max([Lift ID]) 
    FROM [Input Data$] 
    WHERE [Vessel name]='" + shipName + "' 
        AND [Comments] LIKE '%dry dock%'

然后在另一个查询中调用该查询

SELECT TOP 20 
    [Date], 
    [Lift ID]
FROM [Input Data$]
WHERE [Vessel name]='" + shipName + "' 
    AND [Lift ID] >= Iif(
        LikeDryDock >= 1, LikeDryDock, 1
    )
ORDER BY [Date] DESC

【讨论】:

  • 哦,我在写问题时错过了 AND。其实就是在代码里。
  • 您是否分别测试了此查询的每个部分?这些 SELECT 语句中的每一个都应该产生一个可以调试的值。
  • 是的,我已经分别测试了所有这些。仅当我使用 IIF 功能(以及 SWITCH)时才会出现错误
  • 嗯... IIF 各部分后面的分号是否正确?他们不应该是逗号吗? (例如,>=1, 而不是 >=1;
  • @seanb 是对的。当您查看 IIF 时,您可以看到三个参数中只有一个是满足的。它需要用逗号分隔的 3 件事。
猜你喜欢
  • 2017-08-29
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多