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结果呢?
你认为为什么传播数据到多个数据表就能解决丢失数据的问题?我猜你在服务器上有一个不同的excel文件。 –
你可以使用'try-catch'来检查数据集填充过程中是否发生了什么? – lexeRoy
@SteveWellens我检查了服务器上的文件和它的文件。我忘了说它只读了FIRST 12463. –