近日做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;
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/