DB2 decimal 转varchar

针对DB2中decimal类型转换为VarChar类型时出现的问题,本文提供了一种解决方案,通过创建一个自定义函数DecimalToChar来避免导出数据时出现不必要的符号,并确保数值的正确显示。

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

  近日做DB2导入导出工作,decimal类型导出小有问题,前面会加+00000,好吧,这个么,导出的时候做下控制是可以解决的 modified by STRIPLZEROS DECPLUSBLANK.但是这样导出来,如果是整型的话,后面会带个".",这东东比较顽固,没办法限制掉,非常郁闷。平时decimal转varchar也会遇到点儿问题,索性就写个函数,直接转。具体如下:
CREATE FUNCTION DecimalToChar(d_Num decimal(31,5))
RETURNS VARCHAR(31)
RETURN
WITH Temp (ch) AS
(
   SELECT
   CASE WHEN d_Num=0 then '0'
        WHEN SUBSTR(CHAR(d_Num),1,1)='-' THEN
          '-'||REPLACE(RTRIM(REPLACE(REPLACE(TRIM(REPLACE(REPLACE(CHAR(d_Num),'-',''),'0',' ')),' ','0'),'.',' ')),' ','.')
   ELSE
   REPLACE(RTRIM(REPLACE(REPLACE(TRIM(REPLACE(CHAR(d_Num),'0',' ')),' ','0'),'.',' ')),' ','.')
   END
   FROM SYSIBM.SYSDUMMY1
    )
SELECT
  CASE WHEN SUBSTR(ch,1,1)='.' THEN '0'||ch
       WHEN SUBSTR(ch,1,2)='-.' THEN REPLACE(ch,'-','-0')
  ELSE ch
  END
FROM Temp;
----test----
 values DecimalToChar(cast (0.01 as decimal(12,3)));
 
---
0.01
 
 values DecimalToChar(cast (-0.01 as decimal(12,3)));
 
-----
-0.01
其他的可以自行测试。
谁有更好的方法,麻烦告诉我一下,真是郁闷啊,这就是一杯具!
---------------------------------------
郁闷,起初竟然把0这么关键的东东给搞没....
-------------
3月25日早上再次updat..修正负数结果不正确问题

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/23239992/viewspace-630340/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/23239992/viewspace-630340/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值