| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 8142 人关注过本帖
标题:【求助】SQL两个表中的数据做运算,为什么不是最终运算结果?
只看楼主 加入收藏
dibei
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2007-12-8
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:7 
【求助】SQL两个表中的数据做运算,为什么不是最终运算结果?
select a.tmp_warehouse as ack,count(a.tmp_num) as kctm,sum(a.tmp_price_t) as kczj from tmp_kcjl a group by a.tmp_warehouse

select b.tmp_warehouse as bck,count(b.tmp_num) as cktm,sum(b.tmp_price_t) as ckzj from tmp_ckmx b group by b.tmp_warehouse

有a、b两个表,先从两个表中提取相关字段后以tmp_warehouse汇总,然后把汇总后结果做除法运算,该怎么写语句?
a.ack as ck,(b.cktm/(a.kctm+b.cktm)) as tmzzl,(b.ckzj/(a.kczj+b.ckzj)) as jezzl,((b.cktm/(a.kctm+bb.cktm))+(b.ckzj/(a.kczj+bb.ckzj))) as hjzzl 


[此贴子已经被作者于2021-11-20 20:30编辑过]

搜索更多相关主题的帖子: 两个表 运算 结果 SQL 数据 
2021-11-20 16:30
dibei
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2007-12-8
收藏
得分:0 
请各位前辈帮帮忙

[此贴子已经被作者于2021-11-20 20:31编辑过]

2021-11-20 19:38
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分:10 
无关联
程序代码:
SELECT
    aa.ack,
    bb.bck,
    ( bb.cktm / ( aa.kctm + bb.cktm ) ) AS tmzzl,
    ( bb.ckzj / ( aa.kczj + bb.ckzj ) ) AS jezzl,
    (
    ( bb.cktm / ( aa.kctm + bb.cktm ) ) + ( bb.ckzj / ( aa.kczj + bb.ckzj ) ) 
    ) AS hjzzl 
FROM
    (
        SELECT
            a.tmp_warehouse AS ack,
            count( a.tmp_num ) AS kctm,
            sum( a.tmp_price_t ) AS kczj 
        FROM
            tmp_kcjl a 
        GROUP BY
            a.tmp_warehouse 
    ) aa,
    (
        SELECT
            b.tmp_warehouse AS bck,
            count( b.tmp_num ) AS cktm,
            sum( b.tmp_price_t ) AS ckzj 
        FROM
            tmp_ckmx b 
        GROUP BY
            b.tmp_warehouse 
    ) bb 


关联tmp_warehouse
程序代码:
SELECT
    aa.ack,
    bb.bck,
    ( bb.cktm / ( aa.kctm + bb.cktm ) ) AS tmzzl,
    ( bb.ckzj / ( aa.kczj + bb.ckzj ) ) AS jezzl,
    (
    ( bb.cktm / ( aa.kctm + bb.cktm ) ) + ( bb.ckzj / ( aa.kczj + bb.ckzj ) ) 
    ) AS hjzzl 
FROM
    (
        SELECT
            a.tmp_warehouse AS ack,
            count( a.tmp_num ) AS kctm,
            sum( a.tmp_price_t ) AS kczj 
        FROM
            tmp_kcjl a 
        GROUP BY
            a.tmp_warehouse 
    ) aa
    left join
    (
        SELECT
            b.tmp_warehouse AS bck,
            count( b.tmp_num ) AS cktm,
            sum( b.tmp_price_t ) AS ckzj 
        FROM
            tmp_ckmx b 
        GROUP BY
            b.tmp_warehouse 
    ) bb 
    on bb.bck=aa.ack;

剑栈风樯各苦辛,别时冰雪到时春
2021-11-20 20:45
dibei
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2007-12-8
收藏
得分:0 
回复 3楼 林月儿
谢谢大神!
可是tmzzl算出来怎么都是0啊,问题可能出在哪儿呢?

[此贴子已经被作者于2021-11-20 21:12编辑过]

2021-11-20 21:09
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分:0 
前面加上分子分母的查询,看看查的对不对
SELECT
    aa.ack,
    bb.bck,bb.cktm , aa.kctm + bb.cktm,
    ( bb.cktm / ( aa.kctm + bb.cktm ) ) AS tmzzl,
    ( bb.ckzj / ( aa.kczj + bb.ckzj ) ) AS jezzl,
    (
    ( bb.cktm / ( aa.kctm + bb.cktm ) ) + ( bb.ckzj / ( aa.kczj + bb.ckzj ) )
    ) AS hjzzl
。。。。

剑栈风樯各苦辛,别时冰雪到时春
2021-11-20 21:13
dibei
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2007-12-8
收藏
得分:0 
回复 5楼 林月儿
查的是对的
2021-11-20 21:20
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分:0 
哪部分是对的?测试用例有吗

剑栈风樯各苦辛,别时冰雪到时春
2021-11-20 21:24
dibei
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2007-12-8
收藏
得分:0 
问题已解决,感谢版主的指点!!!
程序代码:
SELECT
    aa.ack ,
    ( 1.00*bb.cktm / ( aa.kctm + bb.cktm ) ) AS tmzzl,
    ( bb.ckzj / ( aa.kczj + bb.ckzj ) ) AS jezzl,
    (
    ( 1.00*bb.cktm / ( aa.kctm + bb.cktm ) ) + ( bb.ckzj / ( aa.kczj + bb.ckzj ) ) 
    ) AS hjzzl 
FROM
    (
        SELECT
            a.tmp_warehouse AS ack,
            count( a.tmp_num ) AS kctm,
            sum( a.tmp_price_t ) AS kczj 
        FROM
            tmp_kcjl a 
        GROUP BY
            a.tmp_warehouse 
    ) aa
    left join
    (
        SELECT
            b.tmp_warehouse AS bck,
            count( b.tmp_num ) AS cktm,
            sum( b.tmp_price_t ) AS ckzj 
        FROM
            tmp_ckmx b 
        GROUP BY
            b.tmp_warehouse 
    ) bb 
    on bb.bck=aa.ack;


[此贴子已经被作者于2021-11-20 22:35编辑过]

2021-11-20 21:44
快速回复:【求助】SQL两个表中的数据做运算,为什么不是最终运算结果?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.055804 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved