datagridview 自动更新、删除、添加的问题

huguangwu 2010-05-27 12:08:14
好久没有摸.net了,也不想自己写数据库联接等一大段代码了,想实现最简单的通过datagridview实现数据的添加、修改、删除的功能。我是这样做的:

1)用vs2008(选择的framework2.0)的连接access数据库生成了数据源及dataset

2) 在窗体上放置了一个datagridview,允许添加、修改、删除,并将数据源绑定到dataset里的某一个表(table1)中

3)窗体下方自动生成了 “db1dataset","db1datasetbindinSource","table1BindingSource","table1DataAdapter"

启动窗口显示数据时没问题,我编辑单元格并输入数据,要更新数据库,在datagridview的rowleave事件里

table1BindingSource.update(db1dataset.tables(0))

发现数据已保存到内存中(不关程序,反复打开该数据窗口,有更改后的数据),但并没有更新到数据库,我以为是commandbuilder的问题,又在之前加入:

Dim builder As OleDb.OleDbCommandBuilder = New System.Data.OleDb.OleDbCommandBuilder(table1DataAdapter)

结果提示类型不匹配,我用ctype将其强制转换成oledbdataadapter提示,无法进行转换,另外我还用

db1dataset.tables(0).acceptchanges()

反而连内存中的数据也没有了。


还有一个问题是,我本来想在cellvaluechange事件里写入该代码,可是主键列一更新就自动增长,不知如何解决

请大侠指教,好久没碰了,谢谢!
...全文
1305 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
Qui_suisje 2010-07-24
  • 打赏
  • 举报
回复
借鉴借鉴一下。thx
huguangwu 2010-05-28
  • 打赏
  • 举报
回复
自己搞定了,nnd

table1DataAdapter.adapter.update(tablename)

huguangwu 2010-05-27
  • 打赏
  • 举报
回复
自己顶
皇城龙三 2010-05-27
  • 打赏
  • 举报
回复
http://hi.baidu.com/wangliangandmarker/blog/item/0d209158eb36a4de9c8204c9.html

C#对DataGridView中的数据进行添加、修改、删除操作
huguangwu 2010-05-27
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 myhope88 的回复:]
这种需要有主键,还须设置相应的commandbuilder吧,以前用过,现在很久没用过这样拖控件的了,都是自己写代码来实现
[/Quote]

兄弟,可以重复我的场景,给个提示吗?
myhope88 2010-05-27
  • 打赏
  • 举报
回复
这种需要有主键,还须设置相应的commandbuilder吧,以前用过,现在很久没用过这样拖控件的了,都是自己写代码来实现
wuyq11 2010-05-27
  • 打赏
  • 举报
回复
DataSet ds = new DataSet();
SqlDataAdapter sda;

SqlCommandBuilder scb = new SqlCommandBuilder(sda);
sda.Update(ds);
this.dataGridView1.DataSource = ds.Tables[0];
http://hi.baidu.com/j2eedoc/blog/item/507ca70e1281c4e036d122dc.html
huguangwu 2010-05-27
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 casiniyangyang 的回复:]
用代碼綁定數據源吧,這樣更新好整一些
寫個綁定數數據源的方法,那裡學要哪裡調用多好啊
我才開始摸VB.NET的時候也是直接綁定,但是更新什麽的什麽很不方便,所以建議你用代碼綁定
下麵是我用的綁定的方法:
Imports System.Data.OleDb

Public myDataSet As DataSet

Public da As OleDbDataAdapter
……
[/Quote]

这样写我也会,可是我想用它的控件完成,省去很多手写代码
CASINIYANGYANG 2010-05-27
  • 打赏
  • 举报
回复
用代碼綁定數據源吧,這樣更新好整一些
寫個綁定數數據源的方法,那裡學要哪裡調用多好啊
我才開始摸VB.NET的時候也是直接綁定,但是更新什麽的什麽很不方便,所以建議你用代碼綁定
下麵是我用的綁定的方法:
Imports System.Data.OleDb

Public myDataSet As DataSet

Public da As OleDbDataAdapter
Sub read()
DataGridView1.DataBindings.Clear()
Dim ConnectionString As String = " Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\Me\新資料夾\ceshi\ceshi\TestDatabase.mdb;Persist Security Info=False;Jet OLEDB:Database Password=1234"
Dim myConn As OleDbConnection = New OleDbConnection(ConnectionString)
myConn.Open()
Dim strCon As String = "Select * from CustomerTable where UserID<>' '"
da = New OleDbDataAdapter(strCon, myConn)
myDataSet = New DataSet()
myDataSet.Clear()
da.Fill(myDataSet, "UserInfo")
DataGridView1.DataSource = myDataSet.Tables(0)
myConn.Close()
end sub
huguangwu 2010-05-27
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 forrest23 的回复:]
我也没用过这种拖控件的方法 不过 你这句table1BindingSource.update(db1dataset.tables(0))
应该只是更新的数据源 并没有更新 数据库
应该写一句 table1DataAdapter.update 什么的
[/Quote]

说错了,就是

table1DataAdapter.update(db1dataset.tables(0))

可只更新内存,没更新数据库
huguangwu 2010-05-27
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 ly302 的回复:]
http://hi.baidu.com/wangliangandmarker/blog/item/0d209158eb36a4de9c8204c9.html

C#对DataGridView中的数据进行添加、修改、删除操作
[/Quote]

谢谢,用代码我知道这么写,其实我已提到,但我的问题是用vs的控件拖动出来的,如果实现,能将我的描述看一下吗?
Forrest23 2010-05-27
  • 打赏
  • 举报
回复
我也没用过这种拖控件的方法 不过 你这句table1BindingSource.update(db1dataset.tables(0))
应该只是更新的数据源 并没有更新 数据库
应该写一句 table1DataAdapter.update 什么的
DataGridView控件用法合集 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17. DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 45. DataGridView列中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView添加MaskedTextBox 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)

16,549

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧