zoukankan      html  css  js  c++  java
  • 注意SSIS中的DT_NUMERIC类型转换为字符类型(比如DT_WSTR)时,会截断小数点前的0

    我们知道SSIS中有许多数据类型,如下图所示:

    但是DT_NUMERIC这个类型有个陷进要注意,我们来做个实验,随便定义一个String类型的SSIS包变量,然后打开该变量表达式窗口:

    在变量表达式窗口中,首先我们将一个小数0.05转换为DT_NUMERIC(DT_NUMERIC, 8, 2)类型,然后再将其转换为DT_WSTR(DT_WSTR, 20)类型,然后点击左下方的Evaluate Expression按钮,然后看看Evaluated Value文本框的结果,如下图所示:

    (DT_WSTR, 20) (DT_NUMERIC, 8, 2) 0.05

    我们发现小数0.05最后居然输出的字符串是.05整数部分的0消失了。。。

    我们再来试试-0.05的计算结果,如下图所示:

    (DT_WSTR, 20) (DT_NUMERIC, 8, 2) -0.05

    同样-0.05最后输出的字符串是-.05整数部分的0也消失了。。。

    这是因为在SSIS中如果将DT_NUMERIC类型直接转换为诸如DT_WSTR这样的字符串类型,会将绝对值小于1的小数(比如0.2,0.3, -0.8等)整数位截取掉。

    如果要将DT_NUMERIC转换为DT_WSTR这样的字符串类型,必须要先将DT_NUMERIC转换为DT_DECIMAL,然后再转换为字符串类型DT_WSTR,这样就不会出现本文所述的小数整数截断问题。

    例如我们将0.05先转换为DT_NUMERIC(DT_NUMERIC, 8, 2)类型,然后再转换为DT_DECIMAL (DT_DECIMAL, 2)类型,最后转换为DT_WSTR(DT_WSTR, 20)类型,如下图所示:

    (DT_WSTR, 20) (DT_DECIMAL, 2) (DT_NUMERIC, 8, 2) 0.05

    现在小数0.05就完整的显示出来了。

    所以当DT_NUMERIC类型转换为诸如DT_WSTR这样的字符串类型时要当心,必须要将其先转换为DT_DECIMAL类型,再转换为DT_WSTR这样的字符串类型,避免小数点前的0被截断。虽然我也不知道为什么SSIS有这么一个莫名其妙的问题,但是目前来看只有通过先将DT_NUMERIC类型转换为DT_DECIMAL类型才能解决这个问题。尤其是在某些SSIS数据流任务(Data Flow Task)中用到了DT_NUMERIC类型要特别当心,因为数据流的目标有时候会将DT_NUMERIC类型直接转换为DT_WSTR这样的字符串类型,那么你会发现数据流目标输出的文件中,小数点前的0可能全部都没有。。。要在数据流任务中使用派生列(Derived Column)组件或数据类型转换(Data Conversion)组件,先将DT_NUMERIC类型转换为DT_DECIMAL类型,再输出到数据流目标文件,才能保证目标文件中的小数正确显示。

  • 相关阅读:
    使用Microsoft URL Rewrite Module for IIS 7.0修改WEB.CONFIG即可实现*.HTML伪静态 无需修改应用程序映射
    我的第二个智能手机 HKC G801 严重质量问题 USB接口坏后解决办法
    JQuery的跨域方法 可跨新浪、腾讯等任意网站
    IIS7下使用MSDNURLRewriting.msi开源组件的设置
    面向对象编程,真离不开设计模式?
    jQuery 的filter(),not(),split()用法
    2008年总结
    程序中 同步和异步的经典解释 (一听就懂)
    2009年元旦前祝福 开心一下
    到底什么是SOA?
  • 原文地址:https://www.cnblogs.com/OpenCoder/p/8126852.html
Copyright © 2011-2022 走看看