sqlserver 除零操作

declare @a int ---分子
declare @b int ---分母
select  case  when @b=0 then NULL else @a/@b end  as [a除以b]

isnull的定义如下:

declare @a int ---分子
declare @b int ---分母
select @a/nullif(@b,0) as [a除以b]

set @b=0


nullif函数有两个参数,定义如下:


select @a/nullif(@b,0)

在各种业务系统开发中,通常会遇到除零的错误,下文分享了两种处理方法:
方法1: case when end 

其作用就是:如果两个指定的表达式相等,就返回null值。

摘要:
下文介绍sql server中,sql脚本避免出现除零错误的方法分享

我们知道,null与任何数进行任何运算,其结果都等于null,利用这点,我们可以将上面的sql改写为:

 

(如果有朋友对isnull函数不了解的话,这里可以解释一下。

摘自:http://www.maomao365.com/?p=6612

declare @a int;

方法2:nullif
nullif(表达式A,表达式B)
—-如果表达式A不等于表达式B,则返回表达式A
—-反之返回NULL 

NULLIF( expression , expression )

 

set @a=10

set @b=0

isnull(参数1,参数2)

其作用就是,当参数1等于null时,就返回参数2的值。)

本文由皇家赌场手机版发布于首页,转载请注明出处:sqlserver 除零操作

相关阅读