怎么在mysql中实现多表关联统计
发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,本篇文章为大家展示了怎么在mysql中实现多表关联统计,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。需求:统计每本书打赏金额,不同时间的充值数据统计,消费统计
千家信息网最后更新 2025年02月05日怎么在mysql中实现多表关联统计
本篇文章为大家展示了怎么在mysql中实现多表关联统计,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
需求:
统计每本书打赏金额,不同时间的充值数据统计,消费统计,
设计四个表,book 书本表,orders 订单表 reward_log打赏表 consume_log 消费表 ,通过book_id与book表关联,
问题:
当关联超过两张表时导致统计时数据重复,只好用子查询查出来,子查询只能查一个字段,这里用CONCAT_WS函数将多个字段其拼接
实现:
查询代码如下
SELECTb.id,b.book_name,sum( IF ( o.create_time > 0 && o.create_time < 9999999999, o.price, 0 ) ) today_pay_money,sum( IF ( o.create_time > 0 && o.create_time < 9999999999, 1, 0 ) ) today_pay_num,sum( IF ( o.create_time > 999 && o.create_time < 9999, o.price, 0 ) ) yesterday_pay_money,sum( IF ( o.create_time > 999 && o.create_time < 9999, 1, 0 ) ) yesterday_pay_num,sum(o.price) total_pay_money,sum( IF ( o.create_time > 9999 && o.create_time < 99999, 1, 0 ) ) total_pay_num,( SELECT SUM( total_score ) FROM book_reward_log WHERE book_id = b.id ) total_score,( SELECT CONCAT_WS( ',', SUM( IF ( create_time > 0 && create_time < 998, score, 0 ) ), SUM( IF ( create_time > 9999 && create_time < 99998, score, 0 ) ), SUM( IF ( create_time > 99999 && create_time < 999998, score, 0 ) ) ) FROM book_consume_log WHERE book_id = b.id ) score FROM book_book b LEFT JOIN book_orders o ON b.id = o.bidGROUP BY b.id
查询结果
score 为三个消费数,以逗号隔开
性能分析
上述内容就是怎么在mysql中实现多表关联统计,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
统计
关联
查询
消费
中实
内容
字段
技能
数据
知识
不同
简明
简明扼要
三个
书本
代码
函数
多个
就是
性能
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
云顶之弈测试服是哪个服务器
电脑验证服务器通信失败
h3c网络安全培训文档
北京企业软件开发收费
杭州物流软件开发流程
黄浦区推广软件开发报价表
长沙棋牌软件开发有限公司
网页显示服务器忙是什么意思
网络安全关系你我
hr软件开发合同
预防无线网络安全
mysql 数据库改名
花漾下载软件开发
半月谈下载软件开发
刀剑乱舞服务器哪个好
服务器磁盘有型号吗
im通信软件开发成本
软件开发和网页
关于软件开发的确认
数据库增长太快
网络安全连接
服务器经脉调整教程
数据库事务 跨库
如何开一个软件开发公司
实战经验和网络技术
服务器已停止响应
北京财务软件开发价格
服务器安全狗离线升级
数据库表在哪里新建
软件开发需要学前端吗