CASE (Transact-SQL)

原创 2006年05月17日 15:04:00

计算条件列表并返回多个可能结果表达式之一。

CASE 具有两种格式:  

  • 简单 CASE 函数将某个表达式与一组简单表达式进行比较以确定结果。
  • CASE 搜索函数计算一组布尔表达式以确定结果。
  • 两种格式都支持可选的 ELSE 参数。

语法

 
Simple CASE function: CASE input_expression 
     WHEN when_expression THEN result_expression 
    [ ...n ] 
     [ 
    ELSE else_result_expression 
     ] 
END 
Searched CASE function:
CASE
     WHEN Boolean_expression THEN result_expression 
    [ ...n ] 
     [ 
    ELSE else_result_expression 
     ] 
END

参数

input_expression

使用简单 CASE 格式时所计算的表达式。input_expression 是任意有效的表达式。

WHEN when_expression

使用简单 CASE 格式时要与 input_expression 进行比较的简单表达式。when_expression 是任意有效的表达式。input_expression 及每个 when_expression 的数据类型必须相同或必须是隐式转换的数据类型。

n

占位符,表明可以使用多个 WHEN when_expression THEN result_expression 子句或多个 WHEN Boolean_expression THEN result_expression 子句。

THEN result_expression

当 input_expression = when_expression 计算结果为 TRUE,或者 Boolean_expression 计算结果为 TRUE 时返回的表达式。result expression 是任意有效的表达式。

ELSE else_result_expression

比较运算计算结果不为 TRUE 时返回的表达式。如果忽略此参数且比较运算计算结果不为 TRUE,则 CASE 返回 NULL。else_result_expression 是任意有效的表达式。else_result_expression 及任何 result_expression 的数据类型必须相同或必须是隐式转换的数据类型。

WHEN Boolean_expression

使用 CASE 搜索格式时所计算的布尔表达式。Boolean_expression 是任意有效的布尔表达式。

结果类型

从 result_expressions 和可选 else_result_expression 的类型集中返回优先级最高的类型。

结果值

简单 CASE 函数:

  • 计算 input_expression,然后按指定顺序对每个 WHEN 子句的 input_expression = when_expression 进行计算。

  • 返回 input_expression = when_expression 的第一个计算结果为 TRUE 的 result_expression。

  • 如果 input_expression = when_expression 计算结果不为 TRUE,则在指定 ELSE 子句的情况下 SQL Server 2005 Database Engine 将返回 else_result_expression;若没有指定 ELSE 子句,则返回 NULL 值。

CASE 搜索函数:

  • 按指定顺序对每个 WHEN 子句的 Boolean_expression 进行计算。

  • 返回 Boolean_expression 的第一个计算结果为 TRUE 的 result_expression。

  • 如果 Boolean_expression 计算结果不为 TRUE,则在指定 ELSE 子句的情况下 数据库引擎 将返回 else_result_expression;若没有指定 ELSE 子句,则返回 NULL 值。

示例

A. 使用带有简单 CASE 函数的 SELECT 语句

SELECT 语句中,简单 CASE 函数仅检查是否相等,而不进行其他比较。以下示例使用 CASE 函数更改产品系列类别的显示,以使这些类别更易理解。

 
USE AdventureWorks;
GO
SELECT   ProductNumber, Category =
      CASE ProductLine
         WHEN 'R' THEN 'Road'
         WHEN 'M' THEN 'Mountain'
         WHEN 'T' THEN 'Touring'
         WHEN 'S' THEN 'Other sale items'
         ELSE 'Not for sale'
      END,
   Name
FROM Production.Product
ORDER BY ProductNumber;
GO

B. 使用带有简单 CASE 函数和 CASE 搜索函数的 SELECT 语句

SELECT 语句中,CASE 搜索函数允许根据比较值在结果集内对值进行替换。下面的示例根据产品的价格范围将标价显示为文本注释。

 
USE AdventureWorks;
GO
SELECT   ProductNumber, Name, 'Price Range' = 
      CASE 
         WHEN ListPrice =  0 THEN 'Mfg item - not for resale'
         WHEN ListPrice < 50 THEN 'Under $50'
         WHEN ListPrice >= 50 and ListPrice < 250 THEN 'Under $250'
         WHEN ListPrice >= 250 and ListPrice < 1000 THEN 'Under $1000'
         ELSE 'Over $1000'
      END
FROM Production.Product
ORDER BY ProductNumber ;
GO
《注》:选自SQL Server 2005 联机丛书

CASE的用法 (Transact-SQL)

  • 2014年07月16日 16:54
  • 236KB
  • 下载

Precision, Scale, and Length (Transact-SQL)

Precision is the number of digits in a number. Scale is the number of digits to the right of the dec...

Transact-SQL中自定义函数的限制

Transact-SQL中自定义函数的限制 一直以为自定义函数只是比存储过程多了一个返回值而已,没有想到有这么多的限制,事情的起源都是因为下面这个简单的自定义函数引起的:CREATE FUNCTION...

sp_setsubscriptionxactseqno (Transact-SQL)

SQL Server 2008 R2SQL Server 2008SQL Server 2005 此主题尚未评级- 评价此主题 进行故障排除时,用于指定订阅服务器上的分发...

Transact-SQL函数

一、时间日期函数 unit:YEAR/MONTH/DAY 增加日期类型 年/月/日 n:增加的数字 date:对应的日期 part:YEAR/MONTH/DAY 日期类型 ...

DATEADD (Transact-SQL)

本文转载自MSDN,为了方便访问,谢谢! DATEADD (Transact-SQL) http://msdn.microsoft.com/zh-cn/library/ms186819.asp...

Transact-SQL参考:sp_who

Transact-SQL 参考 sp_who 提供关于当前 Microsoft® SQL Server™ 用户和进程的信息。可以筛选返回的信息,以便只返回那些不...

Transact-SQL语法速查手册

Transact-SQL语法速查手册第1章          Transact-SQL基础1.1 标识符一、常规标识符1.        命名规则:l          第一个字母必须是Unicode...

二 Transact-SQL 语言概述

Transact-SQL 语言的分类如下: 1·数据定义语言(DDL,Data Definition Language) 用来建立数据库、数据库对象和定义其列,大部分是以CREATE 开头...

COLUMNPROPERTY (Transact-SQL)

返回有关列或参数的信息。 Transact-SQL 语法约定 语法 复制 COLUMNPROPERTY ( id , colum...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:CASE (Transact-SQL)
举报原因:
原因补充:

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