用Nullif函数和Case When Then Else End
ISNULL(Expression1,Expression2):如果Expression1是NULL,那么返回Expression2,否则返回Expression1。
等价于:Case WHEN Expression1 is NULL Then Expression2 ELSE Expression1。
-- ISNULL( check_expression , replacement_value )
-- Nullif(expr1,expr2) expr1=expr2返回null;expr1<>expr2返回expr1
-- Case When 分母=0 Then null Else 分子/分母 End
-- Case 分母 When 0 Then null Else 分子/分母 End
-- MySQL
SET @var1=10, @var2=20, @var3=0;
SELECT
@var1/NULLIF(@var2,0),
@var1/NULLIF(@var3,0),
CASE @var2 WHEN 0 THEN NULL ELSE @var1/@var2 END AS var1_var2,
CASE @var3 WHEN 0 THEN NULL ELSE @var1/@var3 END AS var1_var3;