ADO.NET窗体的控件使用复杂绑定后,用OleDbCommandBuilder就不能正常更新数据源了?
做好的这个窗体上有一个ListBox,我是如下写这个控件的代码的:
myAD.SelectCommand = New OleDbCommand("SELECT BASI.BMH, BASI.XM, BASI.XB, BASI.BKKM FROM BASI;", myconn)
myAD.Fill(myDataSet, "BASIC")
Dim cb As OleDbCommandBuilder = New OleDbCommandBuilder(myAD)
myAD.SelectCommand.CommandText = "SELECT KM.KMDH, KM.KMMC FROM KM;"
myAD.Fill(myDataSet, "BloodType")
ListBox1.DataSource = myDataSet.Tables("BloodType")
ListBox1.DisplayMember = "KMMC" '显示的名称
ListBox1.ValueMember = "KMDH" '保存的代号
ListBox1.DataBindings.Add("SelectedValue", myDataSet, "BASIC.BKKM")
当然,在这个窗体上还有一些其他的控件,用来显示myDataSet.Tables("BASIC")中的字段的信息。我还做了“上一条”、“下一条”的浏览功能,这些功能都很正常。
在刚才的代码中我写了一个OleDbCommandBuilder,准备用来进行更高级的功能。例如,删除、更新、插入新记录。
删除按钮,我用了以下代码:
myDataSet.Tables("BASIC").Rows(Me.BindingContext(myDataSet, "BASIC").Position).Delete()
myAD.Update(myDataSet, "BASIC")
却出错了,提示:
DataTable“BASIC”中缺少 SourceColumn“KMDH”的 DataColumn“KMDH”。
是的,KMDH不属于BASIC表,原因就是出在我最开始写的代码——控件数据绑定不是直接绑定单一表的单一字段。
这到底怎解决,哪里还要再改一下?
我被ADO.NET快折磨死了,每前进一步都遇到无比的困难。一点很基本的需求功能,也被微软搞的很复杂。我快死了,快救救我!
如果需要源代码文件,给个邮箱,我发给老师。谢谢!
[解决办法]
1.不是微软搞得复杂,是你没搞明白其中的奥妙。
2.要是认为这项工作是种折磨人的事,是绝对做不好的。
3.检查myAD.UpdateCommand.CommandText 的值应该不是你想要的
[解决办法]
ddddddddddddddddddd