ado.net中数据适配器的insertcommond到底有什么用?

Wills_AceKiller 2014-05-12 12:40:48
我的理解是dataadapter.selectcommand在调用fill方法之后,把数据从数据源移到内存。但是我不知道dataadapter.insertcommand是怎么工作的。
这个数据适配器的作用应该就是提供一种断开连接的处理数据方式,但是很奇怪的是我用如下代码,执行之后datagridview控件中并没有显示新插入的数据,而且数据源也没有插入。
 Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
Dim conn As New SqlConnection()
conn.ConnectionString = "Data Source=(local)\SQLEXPRESS;Initial Catalog=mywork;Integrated Security=True"
Dim mytable As New DataTable
Dim myadapter As New SqlDataAdapter
myadapter.InsertCommand = New SqlCommand("insert into users values(4,'test',1,1111,'bejing','True','False')", conn)

myadapter.SelectCommand = New SqlCommand("select * from users", conn)

myadapter.Update(mytable)

myadapter.Fill(mytable)


DataGridView2.DataSource = mytable
DataGridView1.Refresh()
End Sub

但是如果我不用update方法,而是直接调用 myadapter.InsertCommand.executenonquery(),这样数据不仅能显示了,而且也写进数据库了。但是这样的话数据适配器也就没什么用了。
所以不太明白这个update有什么作用,按照微软的说法,在调用update之前的修改不会写进数据源,可是我调用了也没写进去啊,还是说我用的方法不对。刚开始学,求高手指点
...全文
3693 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
Wills_AceKiller 2014-05-12
  • 打赏
  • 举报
回复
我明白了,就是说我把数据加载到一个地方,修改完之后再调用update方法,.net会根据我之前设置的insertcommand属性来更新数据。
feiyun0112 2014-05-12
  • 打赏
  • 举报
回复
你顺序错了,

首先myadapter.Fill(mytable)加载数据
然后向mytable添加行
最后myadapter.InsertCommand 提交数据到数据库

而具体的InsertCommand 你可用SqlCommandBuilder 生成
http://msdn.microsoft.com/zh-cn/library/system.data.sqlclient.sqlcommandbuilder.aspx
Johnyin 2014-05-12
  • 打赏
  • 举报
回复
你得先用Adapter Fill出一个DataTable,然后直接修改这个DataTable某行某个字段的值,然后再用Adapter的Update 更新, 这样才是在用Adapter更新数据。 你的代码是直接用SQL语句在处理,体现不出什么东东来。

17,748

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 .NET Framework
社区管理员
  • .NET Framework社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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