mysql优化 - mysql计算出来的列,怎么对其计算总数,条件中需要这个列
大家讲道理
大家讲道理 2017-04-17 13:49:37
[MySQL讨论组]
  1. 表结构及字段含义
    borrow:项目表

       attribute_type:项目类型

    borrow_recover:项目还款表

       plan_recover_time:项目计划还款时间

    plan_dun_time:计划催款时间

  2. 需求
    项目类型1 需要提前五天催款,其余项目需要提前31天催款
    现在需要计算:催款时间在某一段时间内的项目的总数。有点难 不知道怎么弄了。

SELECT
    CASE WHEN b.attribute_type = 1  THEN br.plan_recover_time -43200 ELSE br.plan_recover_time - 2678400 END as plan_dun_time
FROM
    borrow_recover br
JOIN borrow b ON br.borrow_id = b.id

HAVING
(
    plan_dun_time BETWEEN 1456416000
    AND 1459094400
)
大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

全部回复(1)
PHPz
SUM(

    IF (
        (
            b.attribute_type = 1
            AND br.plan_recover_time -43200 < 1459094400
            AND br.plan_recover_time -43200 > 1456416000
        )
        OR (
            b.attribute_type != 1
            AND br.plan_recover_time -2678400 < 1459094400
            AND br.plan_recover_time -2678400 > 1456416000
        ),
        1,
        0
    )
)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号