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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k