0

感谢您阅读我的问题。

我有以下查询。

   round(count(product)*100/(select sum(count(product)) FROM FACTORY 
   WHERE TRUNC(COMPLETED) >= '01-MAR-2013' and 
   TRUNC(COMPLETED) <= '31-MAR-2013' 
   group by (product))) as percentage FROM FACTORY

我收到以下错误。

    Error: ORA-01476: divisor is equal to zero
    SQLState:  22012
    ErrorCode: 1476

我试图把 COALESCE 但仍然得到同样的错误。

  round(count(product)*100/(select COALESCE(sum(count(product)),0) FROM FACTORY 
  WHERE TRUNC(COMPLETED) >= '01-MAR-2013' and 
  TRUNC(COMPLETED) <= '31-MAR-2013' 
  group by (product))) as percentage FROM FACTORY

请帮忙。

4

2 回答 2

2

尝试

1)

SELECT  xxx/ NULLIF(yyyy,0) FROM [dbo].[tablename]

或者

2)

SELECT  COALESCE(xxx / NULLIF(yyyy,0), 0) FROM [dbo].[tablename]
于 2013-07-20T14:08:41.937 回答
0

使用 where 子句过滤掉数据,这样您就不会得到 0 值。我在 where 子句中添加了 product !=0

于 2013-07-20T15:47:00.437 回答