该 ISAM 不支持在链接表中删除数据。

数据库 同时被 2 个专栏收录
28 篇文章 0 订阅
100 篇文章 3 订阅

使用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 ISAMExcel访ExcelExcelExcel1DeletingdatainalinkedtableisnotsupportedbythisISAM.2ExcelOperationisnotallowedinthiscontext.3UPDATEsheet1 SET NAME = NULL, DeptName= NULL WHERE DeptId = 1;
当然,你要知道的是,这一行并没有真正删除掉,所以通常在select的时候要进行一定的筛选,例如:SELECT * FROM sheet1$ WHERE DeptId IS NOT NULL;

备注:
1、中转删除法(物理删除)
通过MSSQL的一个语法将EXCEL数据导入到一个MSSQL中一个表里,然后直接操作MSSQL删除表中的某些你要删除的行。再将原EXCEL文件删除或改名,然后从MSSQL的那个表中将数据导出为原EXCEL文件名。

  • 1
    点赞
  • 0
    评论
  • 2
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

参与评论 您还未登录,请先 登录 后发表或查看评论
©️2022 CSDN 皮肤主题:编程工作室 设计师:CSDN官方博客 返回首页

打赏作者

微wx笑

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值