oracle中sql的case语句运用--根据不同条件去排序!

简介: oracle中sql的case语句运用--根据不同条件去排序!

--case语句的种类:

1.简单case语句

语法:

  case exp when comexp then returnvalue

           ...

           when comexp then returnvalue

           else returnvalue

   end

   

 case到end之间相当于一个具体的值,可以做运算,取别名,嵌套case 等等。

 只要把case到end当作一个运算结果的表达式就可以了。


举例:

  select cust_last_name,

         case credit_limit when 100 then 'low'

                           when 5000 then 'high'

                           else 'medium'

         end

    from customers;


--注意事项:

1.case 表达式返回的是一个确定的value,若前面的都不匹配,则返回else中的项(相当于 =,所以也不能匹配null).

2.简单case 中的表达式,when 后面的表达式类型应该全部保持一致.

3.所有的then 后面的return_value类型要保持一致.

4.对于简单case 表达式,也就是case 表达式 when…那么when null 总是取不到。也就是case 后面的表达式如果值为null,不会与when null 匹配,只会与else匹配.


--case中嵌套子查询

Case语句中可以使用子查询,但是必须返回一行,不可以是多行.

如:

select case (select count(*) as s1 from t1 where a = 1)

          when (select count(*) as s2 from t1, t2 where t1.a = t2.a and t2.a = 1) then '相等'

          else '不相等'

      end

 from dual;


***CASE之应用实践:


SELECT JCXX.ID,

      JCXX.FXSJ,

      JCXX.ZT,

      jcxx.xgsj

 FROM T_JCXX JCXX

 JOIN T_ZDRYBK_XQ ZDRY

   ON JCXX.ID = ZDRY.JCXX_ID

 JOIN T_JBXX_ZDRYK RYK

   ON RYK.RYJBXX_ID = ZDRY.ZDRY_ID

  AND RYK.SCBS = '0'

WHERE JCXX.SCBS = '0'

  AND JCXX.SFXXYW = '0'

order by JCXX.ZT,

         case jcxx.zt

           when '0' then

            JCXX.fxsj

           else

            jcxx.xgsj

         end desc nulls last

         ,jcxx.id desc nulls last ;


介绍:T_JCXX 基础表 T_ZDRYBK_XQ  重点人员详情表 T_JBXX_ZDRYK  人员基本信息 关系1:1


需求:根据zt升序,当zt为0时,根据fxsj倒序,当zt为1时,根据xgsj倒序。


id desc nulls last 一般防止脏数据导致前面排序的字段都是为空的。


nulls last 防止脏数据都为空的时候,一般oarcle默认空排序第一个,所以这种数据手动放在最后。


目录
相关文章
|
4月前
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之如何在SQL语句里使用CASE WHEN语句
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
115 2
|
1月前
|
SQL 关系型数据库 MySQL
SQL中,可以使用 `ORDER BY` 子句来实现排序功能
【10月更文挑战第26天】SQL中,可以使用 `ORDER BY` 子句来实现排序功能
85 6
|
2月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
2月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
70 3
|
2月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
64 1
|
3月前
|
SQL
SQL: 巧妙使用CASE WHEN实现查询
文章演示了如何利用SQL中的CASE WHEN语句来有效地进行条件性聚合查询,通过具体示例展示了CASE WHEN在统计分析中的应用技巧。
75 0
|
5月前
|
SQL Oracle 关系型数据库
|
5月前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
354 3
|
5月前
|
SQL 存储 Oracle
TDengine 3.3.2.0 发布:新增 UDT 及 Oracle、SQL Server 数据接入
**TDengine 3.3.2.0 发布摘要** - 开源与企业版均强化性能,提升WebSocket、stmt模式写入与查询效率,解决死锁,增强列显示。 - taos-explorer支持geometry和varbinary类型。 - 企业版引入UDT,允许自定义数据转换。 - 新增Oracle和SQL Server数据接入。 - 数据同步优化,支持压缩,提升元数据同步速度,错误信息细化,支持表名修改。 - 扩展跨平台支持,包括麒麟、Euler、Anolis OS等。
131 0
|
3月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")

热门文章

最新文章

推荐镜像

更多