IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

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

    testcs_dn发表于 2015-07-20 12:53:12
    love 0

    使用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报错“该ISAM不支持在链接表中删除数据”。因为Excel工作表中的行与真正的关系型数据库的行是有些不一样的,所以如果通过编程来访问Excel工作表的数据,那么检索,插入,更新应该是没有问题的,但要是删除的话,就会有一些限制。删除Excel数据时,受到的限制要比从关系数据源中删除数据时更多。在关系数据库中,“行”除了表示一条“记录”外没有其他意义;但在Excel工作表中却不同。可以删除字段(单元格)中的值,但不能:1、一次删除一整条记录,否则将出现以下错误信息:DeletingdatainalinkedtableisnotsupportedbythisISAM.只能通过分别清空各个字段的内容来删除一条记录。2、删除包含Excel公式的单元格中的值,否则将出现以下错误信息:Operationisnotallowedinthiscontext.3、虽然电子表格中已被删除的数据原来所在的行现在是空行,但无法将其删除,而且记录集将继续显示对应于这些空行的空记录。针对这个问题,通常简单的做法就是清空字段的值,类似这样的写法:UPDATEsheet1 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文件名。



沪ICP备19023445号-2号
友情链接