SQL Server Case表达式使用方式

 更新时间:2024年12月25日 08:41:09   作者:-小龙人  
在SQL Server中,Case表达式可以用于条件分支,包括在Select、Update和GroupBy中使用,可以优化SQL语句,提高效率

SQL Server Case表达式

在SQL Server中,在处理条件分支时,使用Case表达式十分便利,对于Case的表达基本用法很简单,但它还有一些我们意想不到的写法,可以为我们的SQL优化,起到事半功倍的效果。 

1.常用Select用法 

例如:

在人物表中对于性别列,我们可以使用数字1表示男,2表示女,0表示其他,在搜索表示数据时,使用Case表达式如下:

--简单Case表达式写法
SELECT Id,
	Name,
	Age,
	CASE SEX 
		WHEN '1' THEN '男'
		WHEN '2' THEN '女'
		ELSE '未知' 
	END AS 性别
 FROM dbo.Person

--搜索Case表达式
SELECT Id,
	Name,
	Age,
	CASE  
		WHEN SEX= '1' THEN '男'
		WHEN SEX= '2' THEN '女'
		ELSE '未知' 
	END AS 性别
FROM dbo.Person

这里的两种写法,简单表达式和搜索表达式效果是一样的,可以根据自己喜好写。 

注意事项:

当Case表达式执行时,匹配到第一个when时,执行就结束了,后面的when条件不会再去匹配,所以要注意条件范围大小的顺序。尽量写else条件,否则显示的数据可能是你意料之外的。

2.Update中使用Case表达式

当需要更新某个字段需要面对多种情况时,一般由对最底层的条件依次往上多次去更新,这样很容易出现事故,使用Case 表达式可以一次更新。 

例如:

针对一张分数表,分数在 [60-70) 内分数 * 0.6,分数在 [70-80) 内分数 * 0.7,分数在 [80-90) 内分数 * 0.8,分数在 [90-100] 内分数 * 0.9。

分数表如下:

如果按条件一步步去更新,这里一定不能先去更新[90-100]分数段的成绩,因为这个分数段的成绩更新后成绩在[81-90]范围内,会被后面的更新再次更新,所以只能从最底层条件[60-70)条件往上依次多次去更新。

如果使用Case表达式可以一次更新所有情况

Update Score 
  Set Score= 
  		Case When Score>=90 And Score<=90 Then Score*0.9
		   	 When Score>=80 And Score<90 Then Score*0.8
		     When Score>=70 And Score<80 Then Score*0.7
		     When Score>=60 And Score<70 Then Score*0.6
			Else Score
  		END

3.Group By 聚合函数中使用Case表达式

针对分数表统计出学生各学科成绩,

如下表:PersonId为学号,Subject:1为语文,2为数学,3为英语。

 SELECT PersonId,
		SUM(CASE WHEN Subject=1 THEN Score ELSE 0 END) AS '语文',
		SUM(CASE WHEN Subject=2 THEN Score ELSE 0 END) AS '数学',
		SUM(CASE WHEN Subject=3 THEN Score ELSE 0 END) AS '英语'
	From Score
 Group By PersonId

实现结果:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vs10安装之后一些列问题

    vs10安装之后一些列问题

    sql05不能用了,数据库又没个08怎么办呢 这时候不用卸载vs10 和sql08、05,只需要安装一个sql08就行了
    2011-12-12
  • Sql Server Management Studio连接Mysql的实现步骤

    Sql Server Management Studio连接Mysql的实现步骤

    本文主要介绍了Sql Server Management Studio连接Mysql的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • SQL Server附加数据库报错无法打开物理文件,操作系统错误5的图文解决教程

    SQL Server附加数据库报错无法打开物理文件,操作系统错误5的图文解决教程

    sqlserver附加数据时,提示无法打开物理文件,操作系统错误5什么原因呢?今天小编给大家分享SQL Server附加数据库报错无法打开物理文件,操作系统错误5的图文解决教程,一起看看吧
    2016-12-12
  • SQL Server Table中XML列的操作代码

    SQL Server Table中XML列的操作代码

    SQL Server Table中XML列的操作代码,需要的朋友可以参考下。
    2011-10-10
  • SQL Server 索引和视图详解

    SQL Server 索引和视图详解

    这篇文章主要为大家介绍了SQLServer索引和视图,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • SQLServer日志收缩的两种方法实现

    SQLServer日志收缩的两种方法实现

    日志文件撑爆了磁盘,log文件不能再存储新的transaction log,本文主要介绍了SQLServer日志收缩的两种方法实现,文中通过图文示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2024-08-08
  • SQL行转列和列转行代码详解

    SQL行转列和列转行代码详解

    这篇文章主要介绍了SQL行转列和列转行代码详解,涉及动态方案和静态方案两种处理方式,具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • sql server编写通用脚本实现获取一年前日期的方法

    sql server编写通用脚本实现获取一年前日期的方法

    这篇文章主要介绍了sql server编写通用脚本实现获取一年前日期,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • sql server服务无法启动的解决方案

    sql server服务无法启动的解决方案

    sql server软件是一款关系型数据库管理系统,具有使用方便可伸缩性好与相关软件集成程度高等优点,我们在数据编程操作时经常会使用这款编程软件,在编程时系统有时会提示sql server服务无法启动,那么大家该如何正常启动呢,下面就由小编来给大家介绍一下如何解决
    2023-11-11
  • sql server导入、导出数据库详细步骤记录

    sql server导入、导出数据库详细步骤记录

    这篇文章主要给大家介绍了关于sql server导入、导出数据库的相关资料,SQL Server 导入和导出向导是一种使你可以将数据从源复制到目标的工具,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-03-03

最新评论