本文主要是介绍[OLEDB]OLEDB对于不同版本Excel的连接字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Excel 2000~2003用:
const string szConnect = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source='{0}'; Extended Properties='Excel 8.0;'";
Excel 2007用:
const string szConnect = "Provider=Microsoft.ACE.OLEDB.12.0; Data Source={0}; Extended Properties='Excel 12.0 XML;'";
其中Extended Properties参数还可以添加HDR=YES/NO属性,当HDR=YES时将第一行记录当成表头(Columns)。
另外还有IMEX=0/1,这个属性意思是自动获取列的类型,比如某列下面的记录都是数值,那么这列的类型就自动匹配为double,否则就是字符串,也可以自动匹配为datetime日期时间类型。
当IMEX=1时,将只扫描前8项记录(8这个默认值可以在注册表[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel\TypeGuessRows]修改),但是这样速度虽然比较快,但有可能不能准确获取该列的真正类型。比如说一个数据表它的第3列数据前8项是1,2,3,4,5,6,7,8,恰好后面的几项是9,A,B,C,D,...这样获取到的第三列的类型就误判为double,而9后面字母将变为空值(null)返回。
如果要扫描所有的行,请设置为IMEX=0。
Extended Properties参数中可用的引擎可以在注册表[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Office\12.0\Access Connectivity Engine\ISAM Formats]下面查到。
参考资料:http://www.connectionstrings.com/excel
这篇关于[OLEDB]OLEDB对于不同版本Excel的连接字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!