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条)

报告相同问题?

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效