探讨SQL Server中Case的不同用法

 我来答
京斯年0GZ
2022-10-20 · TA获得超过6203个赞
知道小有建树答主
回答量:306
采纳率:100%
帮助的人:74.1万
展开全部

  CASE 可能是 SQL 中被误用最多的关键字之一 虽然你可能以前用过这个关键字来创建字段 但是它还具有更多用法 例如 你可以在 WHERE 子句中使用 CASE

  首先让我们看一下 CASE 的语法 在一般的 SELECT 中 其语法如下

  SELECT  =

  CASE

  WHEN  THEN

  WHEN  THEN

  ELSE

  END

  在上面的代码中需要用具体的参数代替尖括号中的内容 下面是一个简单的例子

  USE pubs

  GO

  SELECT

  Title

   Price Range =

  CASE

  WHEN price IS NULL THEN Unpriced

  WHEN price < THEN Bargain

  WHEN price BEEEN and THEN Average

  ELSE Gift to impress relatives

  END

  FROM titles

  ORDER BY price

  GO

  这是 CASE 的典型用法 但是使用 CASE 其实可以做更多的事情 比方说下面的 GROUP BY 子句中的 CASE

  SELECT Number of Titles Count(*)

  FROM titles

  GROUP BY

  CASE

  WHEN price IS NULL THEN Unpriced

  WHEN price < THEN Bargain

  WHEN price BEEEN and THEN Average

  ELSE Gift to impress relatives

  END

  GO

  你甚至还可以组合这些选项 添加一个 ORDER BY 子句 如下所示

  USE pubs

  GO

  SELECT

  CASE

  WHEN price IS NULL THEN Unpriced

  WHEN price < THEN Bargain

  WHEN price BEEEN and THEN Average

  ELSE Gift to impress relatives

  END AS Range

  Title

  FROM titles

  GROUP BY

  CASE

  WHEN price IS NULL THEN Unpriced

  WHEN price < THEN Bargain

  WHEN price BEEEN and THEN Average

  ELSE Gift to impress relatives

  END

  Title

  ORDER BY

  CASE

  WHEN price IS NULL THEN Unpriced

  WHEN price < THEN Bargain

  WHEN price BEEEN and THEN Average

  ELSE Gift to impress relatives

  END

  Title

  GO

  注意 为了在 GROUP BY 块中使用 CASE 查询语句需要在 GROUP BY 块中重复 SELECT 块中的 CASE 块

lishixinzhi/Article/program/SQLServer/201311/11236

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式