sql的where条件中使用case when

场景:

1、使用oracle数据库,数据类型为number,需要正无穷值。

2、数据表中有两个金额值,最大值和最小值, 如10~20, 30 ~40,40以上,数据库中这样设计

id name min max

1 j 10 20

2 v 30 40

3 a 40


问题描述

当金额为参数,通过 金额 > min and 金额 <=最大值 作为sql条件,因为oracle中没有正无穷表示,所以用空来表示无穷大。这样就存在 sql:金额 <= null 的情况。


解决方案:

我们在where条件的后边使用case进行判断

sql 复制代码
select * from t 
where (case when max is not null and monry > min
                 and monry <= max 
              then 1
            when max is null and monry > min
              then 1
           else 0
       end) = 1;
相关推荐
高梦轩4 小时前
MySQL高可用
android·运维·数据库
紫金修道7 小时前
【DeepAgent】概述
开发语言·数据库·python
孟章豪7 小时前
《SQL拼接 vs 参数化,为什么公司禁止拼接SQL?(附真实案例)》
服务器·数据库·sql
荒川之神7 小时前
ORACLE LEVEL函数练习
数据库·oracle
·云扬·8 小时前
【MySQL】实战:用pt-table-sync修复主从数据一致性问题
数据库·mysql·ffmpeg
swIn KWAL8 小时前
【MySQL】环境变量配置
数据库·mysql·adb
shark22222228 小时前
【JOIN】关键字在MySql中的详细使用
数据库·mysql
RATi GORI8 小时前
MySQL中的CASE WHEN语句:用法、示例与解析
android·数据库·mysql
坊钰8 小时前
Java 死锁问题及其解决方案
java·开发语言·数据库
onebound_noah9 小时前
【实战教程】如何通过API快速获取淘宝/天猫商品评论数据(含多语言Demo)
大数据·数据库