你的sql语句,在group by ProducttypeNO,AA.出貨量的分组里,实际有3条记录,所以sum(ProducttotalHight  -AA.出貨量  )实际上等与每条记录的(ProducttotalHight  -AA.出貨量  )×3

解决方案 »

  1.   

    你用了sum分组求和,它当然帮助你加起来啦,你想实现什么功能?
      

  2.   

    看不明白你的,第列的值是什么?44          280.00000 NULL 280.00000
    45           69.92900 NULL 69.92900
    16           705.50000 100 605.500
      

  3.   

    create table PET_BL_In(PetTypeID int,RealWeight decimal(30,5)) 
    create table PET_ManufactureIn(ProductTypeNO int,ProductTotalHight  decimal(30,5))
    insert into PET_BL_In select 13,1209.60000
    insert into  PET_ManufactureIn select  13,        806.40000
    insert into  PET_ManufactureIn select  13,        1209.60000
    insert into  PET_ManufactureIn select  13,        1512.00000 select PetTypeID,實重,出貨量,庫存剩余=(出貨量-實重) from 
    (select ProductTypeNO,sum(ProductTotalHight) as 實重 from PET_ManufactureIn group by ProductTypeNO)a
    left join
    (select PetTypeID,isnull(sum(RealWeight),0)as 出貨量 from PET_BL_In group by PetTypeID)b
    on ProductTypeNO=PetTypeIDdrop table PET_BL_In
    drop table PET_ManufactureIn
    -----------------------------------------------
    PetTypeID , 實重           ,  出貨量         ,   庫存剩余
    13        , 3528.00000    1209.60000     --2318.40000
      

  4.   

    zjcxc(邹建) 都没看明白,我就不白费力气了!:D
      

  5.   

    1.這很明顯是錯的:是因為加關於編號為13的數據有三條記錄,不知道為什麼它取得其中一條記錄做了1209.6 + 1209.6 + 1209.6的相加或是相乘3操作,才會得出上面的結果806.40000+1209.60000+1512.00000=3528.000002.還有,我希望如果出貨數理為0的時候庫量給我量出來:
    這是我上面的語句弄出來的,
    44          280.00000 NULL NULL
    45           69.92900 NULL NULL
    16           705.50000 100 605.500
    -------------------------------------------------------
    因为你用的是left join,所以如果left join 后的表找不到匹配的条件,就会置为null,所以一个整数-null=null
    改成:庫存剩余=(isnull(出貨量,0)-isnull(實重,0))即可!
      

  6.   

    Try:select ProductTypeNO,
    sum(實重) as '實重',
    sum(出貨量) as '出貨量',
    sum(庫存剩余) as  '庫存剩余'
    from (
    select ProductTypeNO,
    ProductTotalHight as '實重',
    cast(0 as numeric(10,2)) as '出貨量',
    ProductTotalHight as  '庫存剩余'
    from  PET_ManufactureIn   
    where ProducttypeNO =13   --如果统计所有,不要这一行
    union all
    select PetTypeID as ProductTypeNO,
    0 as '實重',
    RealWeight as '出貨量',
    -RealWeight as  '庫存剩余'
    from  PET_BL_In   
    where PetTypeID = 13          --如果统计所有,不要这一行
    ) as x
    group by ProductTypeNO
      

  7.   

    老邹:
    我是想知道我的那個SQL語句為什麼得不到正確的結果:下面的數時只是說明顯示格式而以。我是想說如果上面的數據,來做加總的合如果遇到空記錄
    我 希望不要顯示空記錄。
    也是就說我不要數據顯示成這樣樣子:
    44          280.00000 NULL NULL
    45           69.92900 NULL NULL
    16           705.50000 100 605.500
    我要它顯示為這個樣子:44          280.00000 NULL 280.00000  (也就是280.00- NULL = 280.00而不是NULL)
    45           69.92900 NULL 69.92900
    16           705.50000 100 605.500
      

  8.   

    我要它顯示為這個樣子:44          280.00000 NULL 280.00000  (也就是280.00- NULL = 280.00而不是NULL)
    45           69.92900 NULL 69.92900
    16           705.50000 100 605.500 ------------------------------------------
    280.00-isnull(字段名,0)不行么?
    看下isnull联机帮助
      

  9.   

    救命啊。剛運行
    leeboyan(★★宝宝★★) ( ) 信誉:100 
    老哥的SQL語句沒看到
    後面還有這個寶
    drop table PET_BL_In
    drop table PET_ManufactureIn
    把我的數據表給刪除了。有沒能辦法要回來啊:
      

  10.   

    用第三方工具Log Explorer 3.2http://www.ttdown.com/SoftDown.asp?ID=14562
    http://www.yiii.net/app/servlet/net.yiii.club.DownloadServlet?Information_Id=I00023471
    解压缩密码 www.heibai.net
    http://www.ttdown.com/softview_8647.htmLog Explorer for SQL Server v4.0.2
    http://js.fixdown.com/soft/8324.htm注册机产生的是注册码,是两个用解压缩密码解开后,压缩包里也有一个注册机的打开log explorer file=>attach log file->选择服务器和登陆方式->connect->
    选择数据库->attach->左面对话框中browse->view log->就可以看到log记录了
    想恢复的话: 右键log记录 undo transation->选择保存文件名和路径->然后打开该文件到查询分析器里执行
    T-sql代码就可以了例如 如果log是delete table where ...的话,生成的文件代码就是insert table ....
      

  11.   


    log explorer使用的几个问题1)对数据库做了完全 差异 和日志备份
    备份时选用了删除事务日志中不活动的条目
    再用Log explorer打试图看日志时
    提示No log recorders found that match the filter,would you like to view unfiltered data
    选择yes 就看不到刚才的记录了
    如果不选用了删除事务日志中不活动的条目
    再用Log explorer打试图看日志时,就能看到原来的日志2)修改了其中一个表中的部分数据,此时用Log explorer看日志,可以作日志恢复3)然后恢复备份,(注意:恢复是断开log explorer与数据库的连接,或连接到其他数据上,
    否则会出现数据库正在使用无法恢复)
    恢复完后,再打开log explorer 提示No log recorders found that match the filter,would you like to view unfiltered data
    选择yes 就看不到刚才在2中修改的日志记录,所以无法做恢复.
    3)
    不要用SQL的备份功能备份,搞不好你的日志就破坏了.正确的备份方法是:
    停止SQL服务,复制数据文件及日志文件进行文件备份.然后启动SQL服务,用log explorer恢复数据