DataAdapter.update更新无任何反应的原因

public bool UpdateTable(DataTable srcTable, string tableName)
        {
            bool isok = false;
            try
            {

                foreach (DataRow myRow in srcTable.Rows)
                {
                    foreach (DataColumn myColumn in srcTable.Columns)
                    {
                        Console.Write(myRow[myColumn] + "|" + myRow[myColumn].GetType() + "|");
                    }
                    Console.WriteLine();
                }

                command.CommandText = "SELECT * FROM " + tableName;
                SQLiteDataAdapter oda = new SQLiteDataAdapter(command);
                SQLiteCommandBuilder ocb = new SQLiteCommandBuilder(oda);
                oda.SelectCommand = command;
                oda.InsertCommand = ocb.GetInsertCommand();
                oda.DeleteCommand = ocb.GetDeleteCommand();
                oda.UpdateCommand = ocb.GetUpdateCommand();
                oda.Update(srcTable);
                isok = true;
            }
            catch (Exception ex)
            {}
            return isok;
        }

上面的这段代码用一个datagridview读取数据然后修改,然后更新,能够成功。

但是自定义一个datatable,然后想用它来将datatable中的数据写入一个表,就会出问题。

 

这两天同样在处理这个问题,搞了半天,最终发现了,第二种情况不能更新的原因:
oda.Update(srcTable);   问题就在这个方法中
ado.net中的DataAdapter 的Update(datatable)方法都是一种处理流程,获取datatable中的变化记录(增删改)然后分别对增、删、改的每一条记录进行插入、删除、修改。
当datatable不是从数据源表获取而来,而是自定义的(从其他数据源获取,或者干脆手动建的,从空的datagridview修改后得到的),就没有上面的相对的删除和修改的概念了(也许有吧,但是这个增加、删除、修改中有些是不被update接受的)。

update设计的时候就是从最优的角度出发的,只更新发生变化的部分。对自定义的datatable,update把它当作你要写入的数据源中读出的数据表来处理,使用的时候就会出 无更新,只更新插入的,更新失败等 问题。

posted on 2014-05-24 11:48  huiche  阅读(2843)  评论(0编辑  收藏  举报

导航