0

我创建了以下存储过程:

ALTER PROCEDURE [dbo].[ExampleSP]
(
    @SearchText NVARCHAR(4000),
    @ID INT = NULL
)
AS
BEGIN
SET NOCOUNT ON;

SELECT 
deID,
deTitle
FROM tblDemo As de
LEFT JOIN tblLinkTable As lnk ON (lnk.ID = de.deID)
WHERE CONTAINS(cstKeywords, @SearchText)
AND ((@ID IS NULL) OR (lnk.ID = @ID))
GROUP BY deID,Title 
ORDER BY de.Title

但我还需要能够从下表列中找到第一个不为空的字段:

deIntroText、deCompanyText、deTimetableText 和 deExampleText

我需要对从 SELECT 返回的每条记录执行此操作。

所以我意识到我需要创建一个临时列来存储它,我想你需要使用这样的 IF 语句:

IF deIntroText IS NOT Null 
THEN TempFieldToReturn = 1

ELSE IF deCompanyText IS NOT Null 
THEN TempFieldToReturn = 2

ELSE IF deTimetableText IS NOT Null 
THEN TempFieldToReturn = 3

ELSE IF deExampleText IS NOT Null
THEN TempFieldToReturn = 4

所以我的问题是 - 实现这一目标的最佳方法是什么?任何示例将不胜感激。

4

1 回答 1

4

没有真正的捷径 - 只需使用CASE表达式:

SELECT
   /* Other Columns */
  CASE
    WHEN deIntroText IS NOT Null THEN 1
    WHEN deCompanyText IS NOT Null THEN 2
    WHEN deTimetableText IS NOT Null THEN 3
    WHEN deExampleText IS NOT Null THEN 4
  ELSE 5 END as OtherColumn
FROM
  /* Rest of query */

这是一个搜索CASE- 实际上有两个变体CASE。如果所有列都是,我猜是 5 -如果您想要在这种情况下获得结果,NULL您可能会忽略该部分。ELSE 5NULL

于 2012-07-06T08:09:39.140 回答