zoukankan      html  css  js  c++  java
  • EXCEL某列长度超过255个字符导入SQL SERVER2005的处理方法

    问题描述:

        [Excel [1]] 错误: 输出“Excel 源输出”(9) 上的 输出列“Description 3”(546) 出错。返回的列状态是:“文本被截断,或者一个或多个字符在目标代码页中没有匹配项。

    该列在excel中最长为308个字符,但是excel源中的外部列和输出列最多只能设为Nvarchar(255),如果设定长度超过255,则出现警告,源列属性不匹配,执行也通不过。使用Ntext类型也尝试过,不匹配。

    我使用ado.net倒是把它倒入到数据库了,但是发现所有超过255的都被截断了。

    原因分析:

       ADOSSISExcel源对数剧列的长度的判定存在问题。

    解决方案一:

          EXCEL转换成CSV格式,然后使用平面文件源导入数据库。

          需要注意两点:

          1、输出列长度需要手动修改。

          2、注意不同语言造成的Unicode字符转换问题,必要时先切换系统语言,再作转换。

    解决方案二:

         将注册表中

    Jet引擎.
    HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel

    如果是:ACE引擎.
    HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Office\12.0\Access Connectivity Engine\Engines\Excel

    下的TypeGuessRows 项的值设置为0

    Windows server 2003 系统注册表中,JET项位于HKEY_LOCAL_MACHINE\SOFTWARE\MicrosoftWow64Node\

    原因是驱动默认情况下根据列的前8行数据判定列长度,修改为0后需要检查整列数据来判定列长度,超过255个字符默认为ntext格式,少于255个字符则默认为nvarchar(255)

    添加一个数据流.在数据流里.添加一个OLEDB.

    新建一个exceloledb.在这里就不说了.

    只需要将Provider设置为Microsoft Ace Oledb.然后选择Excel文件.

    然后设置Extended Properties属性为Excel 12.0;HDR=YES

    解决方案三:

             使用函数将长度超过255个字符的列切割为多个少于255的列,导入数据库后在进行合并。

             注意Excel的选择性粘贴功能。

            可用函数:Left ,Mid

    经过我测试,通过!

    下载注册表文件

    SELECT len(convert(varchar(1000),人员分工)),*  FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\book1.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...[Sheet1$]order by len(人员分工) desc--select * from Table1 
    select len(
    人员分工),* from OpenRowSet('Microsoft.Jet.OLEDB.4.0', 'Excel 8.0;HDR=Yes;IMEX=1;Database=c:\book1.xls', 'select 人员分工,* from [Sheet1$]') order by len(人员分工) descselect * from OpenRowSet('Microsoft.ACE.OLEDB.12.0', 'Excel 12.0;HDR=Yes;IMEX=1;Database=c:\book1.xls', [Sheet1$])  order by len(人员分工) desc
    select len(
    人员分工),* from OpenDataSource('Microsoft.ACE.OLEDB.12.0', 'Data Source=c:\book1.xls;Extended Properties="Excel 12.0;HDR=Yes;IMEX=0"')...[Sheet1$]order by len(人员分工) desc

  • 相关阅读:
    LeetCode 40. 组合总和 II(Combination Sum II)
    LeetCode 129. 求根到叶子节点数字之和(Sum Root to Leaf Numbers)
    LeetCode 60. 第k个排列(Permutation Sequence)
    LeetCode 47. 全排列 II(Permutations II)
    LeetCode 46. 全排列(Permutations)
    LeetCode 93. 复原IP地址(Restore IP Addresses)
    LeetCode 98. 验证二叉搜索树(Validate Binary Search Tree)
    LeetCode 59. 螺旋矩阵 II(Spiral Matrix II)
    一重指针和二重指针
    指针的意义
  • 原文地址:https://www.cnblogs.com/moss_tan_jun/p/1991611.html
Copyright © 2011-2022 走看看