首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > asp.net >

SQL 有关问题 请问一下

2013-07-20 
SQL 问题 请教一下本帖最后由 hongliangc5dn 于 2013-07-18 18:45:29 编辑环境 :SQL2005错误 :遇到以零作

SQL 问题 请教一下
本帖最后由 hongliangc5dn 于 2013-07-18 18:45:29 编辑 环境 :SQL2005
错误 :遇到以零作除数错误。
SELECT
CASE WHEN complete IS NULL THEN 0 ELSE complete END AS complete,
CASE WHEN task IS NULL THEN 0 ELSE task END AS task
FROM
(SELECT 
(select SUM(complete) FROM staff_base_number where flag = 1 and assess_time_id = 2 and staff_id = [temp].id) as complete,
(select SUM(task) FROM staff_base_number where flag = 1 and assess_time_id = 2 and staff_id = [temp].id) as task
 FROM [staff] AS temp) as staff
 order by complete/task desc    ---这里报错

由于是批量排序 所以无法保证里complete都不为0 求解决办法 
[解决办法]
用case when 试试看。

热点排行