三表(订单表、销售表、采购表)查询、统计语句综合

来源:未知 责任编辑:责任编辑 发表时间:2013-12-22 14:57 点击:

一张订单表
 
estimate_id title
 
一张销售表
 
sell_id estimate_id no sprice snum
 
一张采购表
 
buy_id estimate_id no bprice bnum
 
一个订单对应多个销售和采购(estimate_id),一个销售对应多个采购(no)
 
查询的结果:
 
title   scount    bcount 
 
XX     10.00        5.00
 
BB                               (注:这种情况可能是只有订单,还没有销售和采购)
 
AA    100.00     45.00
 
 ..         ....             .....
 
SQL语句:
 
[sql]
SELECT e. * , s.scount, b.bcount   
FROM tb_estimate AS e  
LEFT JOIN (  
    SELECT SUM( sprice * snum ) AS scount, estimate_id  
    FROM tb_sell  
    WHERE deleted =0  
    GROUP BY estimate_id  
) AS s ON e.estimate_id = s.estimate_id  
LEFT JOIN (  
    SELECT SUM( bprice * bnum ) AS bcount, estimate_id  
    FROM tb_buy  
    WHERE deleted =0  
    GROUP BY estimate_id  
) AS b ON b.estimate_id = e.estimate_id  
WHERE e.deleted =0  
ORDER BY updated DESC  
 
 
 
作者 chuangrain

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • Request.ServerVariables 参数大全
      • 执行全文索引时出现权限不足的解决方法
      • 导入excel文件处理流程节点的解决方案
      • 查看sql修改痕迹(SQL Change Tracking on Table)
      • App数据层设计及云存储使用指南
      • PostgreSQL启动过程中的那些事三:加载GUC参数
      • MongoDB安装为Windows服务方法与注意事项
      • Percolator与分布式事务思考(二)
      • 写给MongoDB开发者的50条建议Tip1
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1