2

我是 SQL 新手,我正在尝试使用一组列创建一个计算字段。但是,其中一些值可能为 NULL。如果它们为 NULL,我不希望计算字段返回 NULL 结果,而是设置一些任意值。

这是计算字段

(ces.EXPERT_SCORE * cirm.CONSUMER_RATING) + (12.5 * scs.SIMILARITY)
4

2 回答 2

1

这样使用IFNULL(tocheckwhat,withwhattoreplace)

(IFNULL(ces.EXPERT_SCORE,5) * IFNULL(cirm.CONSUMER_RATING,5)) + (12.5 * IFNULL(scs.SIMILARITY,5))

应该管用!:)

于 2011-01-27T22:51:16.873 回答
0

您可以使用 COALESCE 运算符

(
 COALESCE(ces.EXPERT_SCORE, <YOUR_ARBIT_VALUE>) * 
 COALESCE(cirm.CONSUMER_RATING, <YOUR_ARBIT_VALUE>)
)
+ (12.5 * COALESCE(scs.SIMILARITY, <YOUR_ARBIT_VALUE>))
于 2011-01-27T22:51:27.870 回答