SQLは、ゼロ除算エラーを解決するための二つの方法であります

実際のプロジェクトでは、我々は分裂して百分率、比率等を求めているSQL文を発生することがあります。現時点では、分母がゼロで発生することがあります。

ここでのソリューションの2種類があります。

 

1. NULLIF機能。

構文NULLIF機能についての最初の話:

NULLIF(expr1と、expr2に)

この手段は:expr1の<> expr2の場合は、expr1をを返します。ただし、expr1 = expr2の言葉場合、NULLが返されます。

 

2.ケース際声明。

ケース際に分母= 0その後、NULL、他の分子/分母

 

これらのメソッドの両方が可能である、個人的に私は、第二の方法と利点を持って、各データベースの互換性を考慮すると、と思います。

--  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;

 

 

 

公開された363元の記事 ウォン称賛74 ビュー190 000 +

おすすめ

転載: blog.csdn.net/sinat_26811377/article/details/104664145