我正在尝试在查询中使用RAISERROR,但无法正常运行。毫无疑问,我正在尝试完全以错误的方式执行此操作。

例如,在下面的代码中,如果DestType字段为空或NULL,我希望它终止查询。

SELECT TOP 1
    DocEntry,
    DocNum,
    CAST(DocDate AS DATE) AS [DocDate],
    CAST(DocDueDate AS date) AS [ShipDate],
    Comments,
    DestType
FROM ....

我尝试将它放在CASE WHEN IN类型的东西中,但这没用。

非常感谢!

最佳答案

RAISERROR是无法内联的语句。

通过SQL-Server 2016(如标记),您可以使用

BEGIN TRY
    Do Something here
END TRY
BEGIN CATCH
    RAISERROR ...parameters...
END CATCH

10-05 19:11