成的命令。 OleDbDataAdapter 不会自动生成为了使对 DataSet 所作的更改和相关联的数据源协调起来所必须的 SQL 语句。但是,如果设置了 OleDbDataAdapter 的 SelectCommand 属性,那么就可以创建 OleDbCommandBuilder 对象,来自动生成 SQL 语句以更新单表。然后,OleDbCommandBuilder 将生成其他任何未设置的 SQL 语句。 每当设置了 DataAdapter 属性,OleDbCommandBuilder 就将其本身注册为 RowUpdating 事件的侦听器。一次只能将一个 OleDbDataAdapter 与一个 OleDbCommandBuilder 对象(或相反)互相关联。 为了生成 INSERT、UPDATE 或 DELETE 语句,OleDbCommandBuilder 会自动使用 SelectCommand 属性来检索所需的元数据集。如果在检索元数据后(例如在第一次更新后)更改 SelectCommand,则应调用 RefreshSchema 方法来更新元数据。 OleDbCommandBuilder 还使用由 SelectCommand 引用的 Connection、CommandTimeout 和 Transaction 属性。如果修改了任何这些属性或者替换了 SelectCommand 本身,用户则应调用 RefreshSchema。否则,InsertCommand、UpdateCommand 和 DeleteCommand 属性都保留它们以前的值。 如果调用 Dispose,则会解除 OleDbCommandBuilder 与 OleDbDataAdapter 的关联,并且不再使用所生成的命令。
3、数据更新中出现的问题: 问题:更新数据后,出现一个奇怪的问题:datagrid中更新的数据出现相同的两条记录 解决方法: a)、更新记录后,清除dataset,再重新填充 dataset1.Tables("表1").Clear() adapter1.Fill(dataset1, "表1") b)、 另一种方法为:在form1的load 过程(Frm1_Load)中定义dataset1.Tables("表1")的主键: dataset1.Tables("表1").PrimaryKey = New DataColumn() {dataset1.Tables("表1").Columns("主键字段")} ''''如是自动编号,可以加入以下内容: dataset1.Tables("表1").Columns("主键字段").AutoIncrement = True dataset1.Tables("表1").Columns("主键字段").AutoIncrementSeed = 1 dataset1.Tables("表1").Columns("主键字段").AutoIncrementStep = 1
''''要确保列中的值唯一,可将列值设置为在表中添加新行时自动递增。 ''''要创建自动递增的 DataColumn,可将列的 AutoIncrement 属性设置为 true。 ''''然后,DataColumn 将从 AutoIncrementSeed 属性中定义的值开始,并且,随着各行的添加, ''''AutoIncrement 列的值将按列的 AutoIncrementStep 属性中具有的值增加。 ''''对于 AutoIncrement 列,建议将 DataColumn 的 ReadOnly 属性设置为 true
4、执行删除操作时出现的问题: 问题: 开始我参照自动生成的datafrom中代码,用: Me.BindingContext(dataset1, "表1").RemoveAt(Me.BindingContext(dataset1, "表1").Position) 发现记录指针乱序,根本不是删除我指定的当前记录 解决方法: 更改为 引用datagrid的CurrentRowIndex,便可删除当前记录,休码如下: Me.BindingContext(dataset1, "表1").RemoveAt(Me.DataGrid1.CurrentRowIndex()) ====================================================================== 以上为我初学vb.net中所遇到的问题及解决方法(在XP上运行通过),如有不当之处,请各位指出,谢谢! 并在此感谢论坛中解答我问题的各位!!!
上一页 [1] [2] |