DB2除法的小数位问题(四舍五入问题)以及其他常用的函数

2024-01-12 02:28

本文主要是介绍DB2除法的小数位问题(四舍五入问题)以及其他常用的函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DB2除法的小数位问题(四舍五入问题)以及其他常用的函数

  • 1. DB2取第一条数据
  • 2. DB2 中指定值排序
    • 2.1 使用case when
    • 2.2 使用decode函数
  • 3. 拼接函数
  • 4. 强制转换类型——cast函数
  • 5. DB2除法的小数位问题(四舍五入问题)
    • 5.1 关于round函数
      • 5.1.1 round()函数的简单理解
      • 5.1.2 round() + cast()函数 实现四舍五入
    • 5.2 dec() + cast()函数 实现四舍五入
  • 6. 其他常用函数
    • 6.1 关于 COALESCE 函数——空字段处理
    • 6.2 trim()函数
    • 6.3 字符串截取函数
      • 6.3.1 substr()函数
      • 6.3.2 left() 与 right() 函数
  • 7. 更多关于DB2的基本操作

1. DB2取第一条数据

  • 语法如下:
    SELECT * FROM SYS_COMPANY_DEPT t FETCH FIRST 1 ROWS only;
    

2. DB2 中指定值排序

2.1 使用case when

  • 先看没有任何排序的数据:
    在这里插入图片描述
  • 使用case when排序,如下:
    --要求排序顺序:2,3,0,1SELECT * FROM SYS_COMPANY_DEPT t
    ORDER BY (CASE t.DEPT_LEVEL WHEN '2' THEN 1 WHEN '3' THEN 2 WHEN '0' THEN 3 WHEN '1' THEN 4 ELSE t.DEPT_LEVEL end)
    
    在这里插入图片描述

2.2 使用decode函数

  • 如下:
    --要求排序顺序:2,3,0,1SELECT decode(t.DEPT_LEVEL,'2',1,'3',2,'0',3,'1',4), t.* 
    FROM SYS_COMPANY_DEPT t
    ORDER BY decode(t.DEPT_LEVEL,'2',1,'3',2,'0',3,'1',4)
    
    在这里插入图片描述

3. 拼接函数

  • 这个简单了,使用"||" 或者 concat函数,如下:
    SELECT 'aa' ,'aa'||'-bb',CONCAT('cc','@dd')
    FROM "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

4. 强制转换类型——cast函数

  • 简单使用,如下:
    SELECT CAST(123.66666 AS decimal(10,2)), cast(date('2023-12-31') AS int) num_1
    FROM "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述
  • 如果要处理四舍五入,请继续往下……

5. DB2除法的小数位问题(四舍五入问题)

5.1 关于round函数

5.1.1 round()函数的简单理解

  • 与oracle大同小异,可以参考oracle的此函数进行理解(3.5 ROUND() 与 TRUNC() 函数),如下:
    Oracle 常用简单sql操作(insert into、merge into、start with connect by prior以及 regexp_substr等各种函数用法详解).
  • 然后感受一下db2中此函数的使用,如下:
    SELECT round(0.6666,2) num_1,
    (2/3) num_2, --与oracle不同
    round(2/3,2) num_3, --与oracle不同
    round(2/3) num_4,
    round(0.3333,2)
    FROM "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

5.1.2 round() + cast()函数 实现四舍五入

  • 效果对比sql如下:
    -- 结果对比
    SELECT round(0.6666,2) num_1,--正常四舍五入
    (2/3) num_2,--0 数据不对
    round(2/3,2) num_3,--0 数据不对
    CAST((2/3) AS decimal(10,2)) num_4,--0 数据不对
    CAST(2 AS decimal)/3 num_5,--0.66666666666666666666666666 
    cast(CAST(2 AS decimal)/3 AS decimal(10,2)) num_6,--保留2位小数,不四舍五入
    cast(round(CAST(2 AS decimal)/3,2) AS decimal(10,2)) num_7,--round(CAST(2 AS decimal)/3,2) 使用cast让计算结果正常,使用round保留2位小数
    round(CAST(2 AS decimal)/3,2) num_8 --优化一下 num_7 的写法,最外层直接round处理即可
    FROM "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述
  • 最终sql如下:
    --实现四舍五入最终SQL
    SELECT round(0.6666,2) num_1,--正常四舍五入,但是只处理没有计算过程的数据
    cast(round(CAST(2 AS decimal)/3,2) AS decimal(10,2)) num_7,--round(CAST(2 AS decimal)/3,2) 使用cast让计算结果正常,使用round保留2位小数
    round(CAST(2 AS decimal)/3,2) num_8 --优化一下 num_7 的写法,最外层直接round处理即可
    FROM "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

5.2 dec() + cast()函数 实现四舍五入

  • 先看dec()函数单独使用,如下:
    SELECT 
    dec(0.6666,10,2) num_1,--保留2位,但不四舍五入
    dec(0.6666 + 0.5) num_2,--四舍五入 且 保留整数
    dec(0.6666 + 0.05,10,1) num_3,--四舍五入 且 保留1位
    dec(0.6666 + 0.005,10,2) num_4,--四舍五入 且 保留2位
    dec(0.6666 + 0.0005,10,3) num_5,--四舍五入 且 保留3位
    dec(2/3) num_6,
    dec(2/3 + 0.0005,10,3) num_7
    from "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述
  • dec() + cast() 结合使用
    SELECT 
    dec(2/3) num_6,
    dec(2/3 + 0.0005,10,3) num_7,
    dec(CAST(2 AS decimal)/3 ,10,2) num_8, --保留2位,但不四舍五入
    dec(CAST(2 AS decimal)/3 + 0.5) num_9, --四舍五入 且 保留整数
    dec(CAST(2 AS decimal)/3 + 0.05 ,10,1) num_10, --四舍五入 且 保留1位
    dec(CAST(2 AS decimal)/3 + 0.005 ,10,2) num_11 --四舍五入 且 保留3位
    from "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

6. 其他常用函数

6.1 关于 COALESCE 函数——空字段处理

  • 有点 nvl() 函数的意思,如下:
    SELECT NULL,COALESCE(NULL,'')
    from "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

6.2 trim()函数

  • 如下:
    --rtrim 去掉字符串右边的空格
    --ltrim 去掉字符串左边的空格
    --trim 去掉字符串左右两边的空格SELECT trim(' abc '),ltrim(' abc '),rtrim(' abc '),length(rtrim(' abc ')),length(trim(' abc '))
    from "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

6.3 字符串截取函数

6.3.1 substr()函数

  • 简单不多说,直接看,如下:
    SELECT 
    SUBSTR('abcdef',2,3) , --从第二个字符开始截取,截取3个字符
    SUBSTR('123456',2,LENGTH('123456')-2), --截掉前后的字符
    SUBSTR('123456',LENGTH('123456')-1,2)  --只截取最后两个字符
    FROM "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

6.3.2 left() 与 right() 函数

  • 如下:
    SELECT 
    left('123456',3), --截取前3个
    RIGHT('123456',2) --截取后2个
    FROM "SYSIBM".SYSDUMMY1 s ;
    
    在这里插入图片描述

7. 更多关于DB2的基本操作

  • 关于DB2的更多,可参考下面的文章:
    • 使用docker安装db2.
    • DB2中常见基础操作 ➕ DB2实现递归查询 ➕ DB2中自定义递归函数.
    • DB2中实现数据字段的拼接(LISTAGG() 与 xml2clob、xmlagg).
    • db2中多种方式备份数据(含db2中clob字段如何使用create table as方式备份).

这篇关于DB2除法的小数位问题(四舍五入问题)以及其他常用的函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/596513

相关文章

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1