SQLSERVER-CASE关键词的用法 .

转载 2013年12月05日 12:16:13
在Oralce中有个函数为Decode(),感觉非常好用,但是此函数为Oracle所独有,在SQLSERVER和MYSQL中实现与之相类似的功能还无相关函数,但通过CASE关键词可实现类似功能。
1 》》首先让我们看一下 CASE 的语法。在一般的 SELECT 中,其语法如下:

SELECT =
CASE
WHEN THEN
WHEN THEN
ELSE
END


2 》》 我在SQLSERVER2000的实践

表t_notice有字段result为INT类型,有三种值:0表示发送成功,1表示发送失败,-1表示未发送,需查询出RESULT的值并返回数值所代表的中文。
  SELECT count(*), "result"=CASE        //单引号内的result为别名
  WHEN result=0 THEN "发送成功"
  WHEN result=1 THEN "发送失败"
  WHEN result=-1 THEN "未发送"
  END
  FROM t_notice
  ORDER BY  result

3 》》用Hibernate做持久化,HQL的写法
  SELECT count(*), CASE  WHEN result=0 THEN "发送成功"
  WHEN result=1 THEN "发送失败"
  WHEN result=-1 THEN "未发送"
  END
  FROM TNotice
  ORDER BY  result

注: TNotice为持久化类类名,HQL用CASE时,无需为查询字段加别名。


4 》》以上是 CASE 的典型用法,但是使用 CASE 其实可以做更多的事情。比方说下面的 GROUP BY 子句中的 CASE: SELECT "Number of Titles", Count(*)
FROM titles
GROUP BY
CASE
WHEN price IS NULL THEN "Unpriced"
WHEN price < 10 THEN "Bargain"
WHEN price BETWEEN 10 and 20 THEN "Average"
ELSE "Gift to impress relatives"
END

你甚至还可以组合这些选项,添加一个 ORDER BY 子句,如下所示:
SELECT
CASE
WHEN price IS NULL THEN "Unpriced"
WHEN price < 10 THEN "Bargain"
WHEN price BETWEEN 10 and 20 THEN "Average"
ELSE "Gift to impress relatives"
END AS Range,
Title
FROM titles
GROUP BY
CASE
WHEN price IS NULL THEN "Unpriced"
WHEN price < 10 THEN "Bargain"
WHEN price BETWEEN 10 and 20 THEN "Average"
ELSE "Gift to impress relatives"
END,
Title
ORDER BY
CASE
WHEN price IS NULL THEN "Unpriced"
WHEN price < 10 THEN "Bargain"
WHEN price BETWEEN 10 and 20 THEN "Average"
ELSE "Gift to impress relatives"
END,
Title


注意,为了在 GROUP BY 块中使用 CASE,查询语句需要在 GROUP BY 块中重复 SELECT 块中的 CASE 块。
除了选择自定义字段之外,在很多情况下 CASE 都非常有用。再深入一步,你还可以得到你以前认为不可能得到的分组排序结果集
 
原文地址:http://blog.csdn.net/jojoy_828/article/details/1911366

SQLSERVER-CASE关键词的用法

在Oralce中有个函数为Decode(),感觉非常好用,但是此函数为Oracle所独有,在SQLSERVER和MYSQL中实现与之相类似的功能还无相关函数,但通过CASE关键词可实现类似功能。 1 ...
  • jojoy_828
  • jojoy_828
  • 2007年12月02日 00:10
  • 1643

C语言关键字用法

sbit:定义特殊功能寄存器的位变量,如:sbit P0_0=P0^0;//即定义P0_0为P0口的第1位 sfr:可以对51内部的寄存器进行定义,定义格式:sfr 变量名=变量地址。你打开reg51...
  • qq_31389903
  • qq_31389903
  • 2016年06月22日 14:04
  • 515

全局变量关键字global的使用

先看一个实例: $a = 1; $b = 2; function Sum() {     global $a, $b; //在里面声明为全局变量     $b = $a...
  • daijiguo
  • daijiguo
  • 2015年07月14日 15:36
  • 455

python中关键词with的使用

http://stackoverflow.com/questions/3012488/what-is-the-python-with-statement-designed-for 非常好的回答,值得...
  • haipengdai
  • haipengdai
  • 2016年05月10日 11:08
  • 407

Groovy探索 “as”关键字的深入使用

                 Groovy探索 "as"关键字的深入使用  在前面的系列《Groovy Tip 20  "as"关键字的用法》中,我们已经谈到了"as"关键字的一些激动人心的用法。...
  • hivon
  • hivon
  • 2009年04月22日 07:59
  • 3891

java关键字friendly

“friendly”(友好的)涉及“包装”或“封装”(Package)的概念——即Java 用来构建库的方法。若某样东西是“友好的”,意味着它只能在这个包装的范围内使用(所以这一访 问级别有时也叫作...
  • u011865928
  • u011865928
  • 2015年05月06日 15:20
  • 261

Java中特殊关键字的用法及效果

transient: 修饰的成员变量不会被序列化(serialization)。
  • u014219228
  • u014219228
  • 2014年10月25日 17:26
  • 370

我所认为的 typedef关键字 的用法

typedef的通俗理解:     为现有类型创建一个新的名字。     typedef定义从关键字typedef开始,后面跟数据类型和标识符。标识符和数据类型没有引入新的标识符,而是现有类型数据...
  • Strong_HCyouth
  • Strong_HCyouth
  • 2016年12月02日 20:40
  • 224

Python with 关键字详解

在Python中with关键字很常用,相信你也经常遇见,例如: if isinstance(self.commands, str): with(settings(warn_only = Tr...
  • karchar
  • karchar
  • 2015年10月09日 20:22
  • 755

explicit关键词用法

转载原文地址:http://www.cnblogs.com/cutepig/archive/2009/01/14/1375917.html 向原作者致敬! 按照默认规定,只有一...
  • zhiren2011
  • zhiren2011
  • 2015年09月12日 10:51
  • 267
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQLSERVER-CASE关键词的用法 .
举报原因:
原因补充:

(最多只允许输入30个字)