专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > VB Dotnet

ADO.NET窗体的控件使用复杂绑定后,用OleDbCommandBuilder就不能正常更新数据源了?解决方法

发布时间:2011-06-23 16:01:59 文章来源:www.iduyao.cn 采编人员:星星草
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
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: