mysql 动态 select (NULLIF)

本文介绍了一种基于SQL的动态查询方法,通过NULLIF和ISNULL函数处理空值,并利用IF语句实现条件动态过滤,确保了GROUP BY操作的有效性和灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

根据传入的参数是否有值来决定select的列是否有该字段,以便group by

SELECT
        f_hour AS Hour,
        MAX(`f_speed`) AS max,
        MIN(`f_speed`)AS min,
        AVG(`f_speed`)AS avg,
        COUNT(*)AS hourCount,
        NULLIF (#{taskName},NULL )AS taskName
        FROM `f_record`
        <include refid="page_where_sql"/>
        GROUP BY `f_hour`
<!-- 查询Where语句 -->
    <sql id="page_where_sql">
        <where>
            1=1
                <if test="taskName!=null">AND task_name = #{taskName} </if>
                <if test="Date!=null">AND f_date = #{Date}</if>
        </where>
    </sql>

 

  • NULLIF(expr1,expr2)  的用法:  如果expr1 =  expr2  成立,那么返回值为NULL,否则返回值为   expr1。
  • ISNULL(Expression1,Expression2):给定两个参数Expression1和Expression2,如果Expression1是NULL,那么返回Expression2,否则返回Expression1。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值