mysql tp5关联查询DB,一对多
未知
2020-01-19 08:52:40
0
问题描述:
     一个admin表,字段id,zhandian_id;一个用户积分表,字段user_id;一个商品表,字段site_id。他们的关系是:site_id=zhandian_id,id=user_id。需求是查询各个站点的所有员工在时间段内的成交总额和所产生的积分、站点的所有员工的剩余积分

解决办法:
方法一:


         $list=Db::name("admin")->alias('ad')

        ->where('ad.is_work',1)

         ->where('ad.zhandian_id','not null')

        ->group('ad.zhandian_id')

        ->field('ad.zhandian_id,sum(ad.integral) as shengyujifen,
                (
            select sum(order_price)
            from gczywxcx_order
            where site_id = ad.zhandian_id
                and `order_state` = 2
                AND `is_type` = 3
                AND `confirm_date` BETWEEN '.strtotime($k3.'00:00:00').'  AND '.strtotime($k4.'23:59:59').'
        ) as sumPrice,(
            select sum(fee)
            from gczyadmin_integlog
            where user_id in (select id from gczyc_admin where zhandian_id = ad.zhandian_id)
                AND `type` = 1
                AND `add_date` BETWEEN '.strtotime($k3.'00:00:00').' 
                  AND '.strtotime($k4.'23:59:59').'
        ) as chanfen)
               ->order('sumPrice','desc')
               ->select();

方法二:
             $list=Db::name('admin_integlog')->alias('inte')
        ->join('admin ad','ad.id=inte.user_id')
        ->group('ad.zhandian_id')
        ->field('ad.zhandian_id,

            sum(if(type=1 and inte.add_date BETWEEN '.strtotime($k3.'00:00:00').' AND '.strtotime($k4.'24:00:00').' , inte.fee,0)) as chanfen,

            (SELECT sum( order_price ) FROM gczyc_wxcx_order WHERE site_id = ad.zhandian_id AND `order_state` = 2 AND `is_type` = 3    AND `confirm_date` BETWEEN '.strtotime($k3.'00:00:00').' AND '.strtotime($k4.'24:00:00').') as sumPrice ,

            sum(inte.fee) as leijifen,           

            sum(if(type=0, inte.fee,0)) as leijiyongfen,           

            sum(if(type=1, inte.fee,0)) as leijichan,

            sum(if(type=2, inte.fee,0)) as leijiyi,

            sum(if(type=3, inte.fee,0)) as cancelorder

            ,(select description from gczyc_jiayouzhan jia where id=ad.zhandian_id ) as description'

        )

        ->select();

相关内容

深入理解MySQL视图的工...
摘要: MySQL视图是一种虚拟表,通过封装SQL查询定义。它不...
2026-01-31 01:23:34
MySQL视图与普通表的区...
MySQL视图与普通表:虚拟与实际的存储方式,视图只可查询不可修改...
2026-01-30 01:23:36
MySQL视图:基础概念与...
MySQL视图是一种虚拟的表,由SQL查询定义。创建视图需使用CR...
2026-01-29 01:23:44
学习和实践:MySQL视图...
本文分享了MySQL视图的定义、作用和实战案例,包括简化复杂查询、...
2026-01-28 01:23:47
常见MySQL视图问题及解...
MySQL视图常见问题包括命名冲突、依赖性管理、性能问题和安全性问...
2026-01-27 01:23:44
如何优化MySQL中的视图...
摘要: 本文介绍了如何优化MySQL中视图性能的策略,包括减少查...
2026-01-26 01:23:37

热门资讯

`ISNULL` 摘要:`ISNULL` 函数用于数据库中检查字段值是否为 NULL。它广泛应用于数据验证、清理、查询...
mysql 多个站点的近30天... SELECT j.title, ( SELECT sum( realoil_price ) FROM...
mysql Please DI... mysql插入数据表时总是提示 Please DISCARD the tablespace befo...
sql 批量修改表前缀 示例:将dede_前缀修改成xiong_前缀 先查询以 dede_ 前缀的表: 需要修改的部分:re...
tp5中MySQL如何获取JS... 第一种: // 假设$user是从数据库中查询出的用户信息 $user = Db::name(use...
mysql 一次查询,返回多个... 问题描述: 在一个表中有多个条件,其中两个条件是共同的,另外两个条件是不同,一条sql语句返回多个统...
phpstudy在linux上... 开始配置 在线安装phpstudy一键包: 1.在Xshell里面输入wget -c http://...
使用Linux安装phpstu... 问题描述: 买了阿里云,配置好PHPstudy后好久没用,后来登录mysql,忘记密码,所以登录不上...
mysql把表中数据插入到其他... 两张字段相同的表,一张作为产品库,一张作为自定义库,每增一个新客户就把产品库中的所有数据插入到...
sql注入方法及防御危害 SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服...