MrChuHello

  今天上午,客户提出一个问题,项目上线后有许多数据需要导入到数据库。客户希望能提供一份EXCEL表格式的数据能够直接导入到SQLserver数据库中,省的一条条添,太费人力。

  心想不就是个导入EXCEL吗,多年前就写过N回。于是一挥而就,结果读取数据后发现 有许多数据读取到是空的。。郁闷。。查找资料后 所得

  在使用 ADO.NET 导出 Excel 文件时,连接字符串里面已经设置了 IMEX=1,仍有部分数据不能导出,经过研究,需要在注册表中进行设置 TypeGuessRows 的配置,默认情况下,驱动程序会扫描前 8 行数据,来对数据类型进行采样。设置为 0 ,将对列的所有行进行扫描,如果前八行采样数据都是数值类型的话,设置 IMEX = 1 也不会将剩下的行的默认数据类型转换为文本,它将保留数值类型,也就是把整个列当成数字类型对待。 因此,要想得到完整的数据,需要修改注册表的设置 TypeGuessRows 为 0。TypeGuessRows 在注册表的位置:

[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel]

Windows 7等 64 系统:
[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Jet\4.0\Engines\Excel]

IMEX 的可能设置是:

0 Export 模式
1 Import 模式
2 Linked 模式(full update capabilities)

设置 TypeGuessRows 为 0 将会导致性能的下降。IMEX=1 数据内容也能出现不正常的现象,比如长数字可能会出现科学计数法的格式显示。比较好的做法是导出前,对所有单元格进行处理,在单元格内容前面加 \'。

 

 

感谢网络大神。

分类:

技术点:

相关文章:

  • 2021-11-30
  • 2022-01-21
  • 2021-12-19
  • 2021-12-19
  • 2021-11-20
  • 2022-01-01
  • 2021-12-02
  • 2021-11-17
猜你喜欢
  • 2021-10-19
  • 2021-05-22
  • 2021-11-24
  • 2021-10-06
  • 2021-10-17
  • 2021-09-08
相关资源
相似解决方案