ds3422222222 2018-04-25 17: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-25 17: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条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部