ds3422222222 2018-04-26 01:44
浏览 65
已采纳

如何将此SQL转换为Laravel雄辩?

I have the following SQL

SELECT C.CUOCODE, C.NAME, COUNT(*) TOTAL_PAYMENT, SUM(P.AMOUNT) TOTAL_AMOUNT
FROM TAX_PAYMENT P
INNER JOIN TAX_CHECKPOINT C ON C.CUOCODE = REGEXP_SUBSTR(P.INVOICEID, 'R....')
WHERE DELETED = 0 AND TO_CHAR(TXTIME,'YYYY-MM-DD') = '2018-04-24'
GROUP BY  C.CUOCODE, C.NAME
ORDER BY TOTAL_AMOUNT DESC;

How can i convert to laravel eloquent, i have "Payment" model (table TAX_PAYMENT) with "paymentid" as primary key.

  • 写回答

2条回答 默认 最新

  • dsxsou8465 2018-04-26 01:58
    关注
    DB::table('TAX_PAYMENT as P')
        ->select([
            'C.CUOCODE',
            'C.NAME',
            DB::raw('COUNT(*) AS TOTAL_PAYMENT'),
            DB::raw('SUM(P.AMOUNT) AS TOTAL_AMOUNT'),
        ])->Join('TAX_CHECKPOINT C', 'C.CUOCODE', '=', DB::raw('REGEXP_SUBSTR(P.INVOICEID,'R....')'))
        ->where('DELETED', 0)
        ->where(DB::raw("TO_CHAR(TXTIME,'YYYY-MM-DD')"), '2018-04-24')
        ->groupBy('C.CUOCODE')
        ->groupBy('C.NAME')
        ->orderBy('TOTAL_AMOUNT', 'desc')
        ->toSql();
    

    output

    SELECT
        `C`.`CUOCODE`,
        `C`.`NAME`,
        COUNT(*) AS TOTAL_PAYMENT,
        SUM(P.AMOUNT) AS TOTAL_AMOUNT
    FROM
        `TAX_PAYMENT` AS `P`
    INNER JOIN `TAX_CHECKPOINT C` ON `C`.`CUOCODE` = REGEXP_SUBSTR (P.INVOICEID,"R....")
    WHERE
        `DELETED` = ?
    AND TO_CHAR (TXTIME, 'YYYY-MM-DD') = ?
    GROUP BY
        `C`.`CUOCODE`,
        `C`.`NAME`
    ORDER BY
        `TOTAL_AMOUNT` DESC
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记