使用OleDB方式操作Excel,删除表中的数据时提示该错误
相关代码:
连接字符串:
//定义OleDB连接字符串
string strConn = "Provider=Microsoft.Ace.OleDb.12.0;Persist Security Info=False;" + "data source=" + @excelPath + ";Extended Properties='Excel 12.0; HDR=yes; IMEX=10'";
OleDbConnection conn = new OleDbConnection();
conn.ConnectionString = strConn;
执行删除的代码:
try
{
cmd = new OleDbCommand("Drop Table [" + roadmapTableName + "]", conn);
cmd.ExecuteNonQuery();
}
catch (System.Exception ex)
{
textBox1.Text += ("删除数据表失败:" + ex.Message);
textBox1.Text += ("\r\n");
//该 ISAM 不支持在链接表中删除数据。
cmd = new OleDbCommand("Delete From [" + roadmapTableName + "]", conn);
cmd.ExecuteNonQuery();
}
原来Excel不支持删除,DELETE FROM sheet1
当然,你要知道的是,这一行并没有真正删除掉,所以通常在select的时候要进行一定的筛选,例如:SELECT * FROM sheet1$ WHERE DeptId IS NOT NULL;
备注:
1、中转删除法(物理删除)
通过MSSQL的一个语法将EXCEL数据导入到一个MSSQL中一个表里,然后直接操作MSSQL删除表中的某些你要删除的行。再将原EXCEL文件删除或改名,然后从MSSQL的那个表中将数据导出为原EXCEL文件名。