2013-03-31 110 views
2

我使用OleDbDataAdapter读取数据集中Excel工作表的内容。 Excel工作表包含20391行,数据集读取在本地机器上运行时的总行数,但在IIS7.5服务器上运行代码时,它只读取FIRST 12463!从OleDbDataAdapter填充数据集

我的连接字符串:

switch (strFileType.Trim()) 
     { 
      case ".xls": 
       connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + strNewPath + 
          ";Extended Properties=\"Excel 8.0;HDR=Yes;IMEX=2\""; 
       break; 
      case ".xlsx": 
       connString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + strNewPath + 
          ";Extended Properties=\"Excel 12.0;HDR=Yes;IMEX=2\""; 
       break; 
     } 

var query = "SELECT * FROM [" + excelSheets[0] + "]"; 

//Create the connection object 
var conn = new OleDbConnection(connString); 
//Open connection 
if (conn.State == ConnectionState.Closed) conn.Open(); 
//Create the command object 
var cmd = new OleDbCommand(query, conn); 
var da = new OleDbDataAdapter(cmd); 
var ds = new DataSet(); 
da.Fill(ds); 

有没有办法在多个数据表来划分da.Fill结果呢?

+0

你认为为什么传播数据到多个数据表就能解决丢失数据的问题?我猜你在服务器上有一个不同的excel文件。 –

+0

你可以使用'try-catch'来检查数据集填充过程中是否发生了什么? – lexeRoy

+0

@SteveWellens我检查了服务器上的文件和它的文件。我忘了说它只读了FIRST 12463. –

回答

1

我做了什么@dash建议和使用Excel Data Reader它工作正常。

这里是代码

 FileStream stream = File.Open(strNewPath , FileMode.Open, FileAccess.Read);    
     //1. Reading from a binary Excel file ('97-2003 format; *.xls) 
     //IExcelDataReader excelReader = ExcelReaderFactory.CreateBinaryReader(stream); 
     //... 
     //2. Reading from a OpenXml Excel file (2007 format; *.xlsx) 
     IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);;      
     excelReader.IsFirstRowAsColumnNames = true; 
     DataSet result = excelReader.AsDataSet();