datagrid无法更新数据库(等待中)

nakhi 2003-09-18 04:20:01
在Page_load()执行:
da = New OleDbDataAdapter("select * from files", cnstring)
ds = New DataSet
da.Fill(ds, "t")
dg.DataSource = ds.Tables("t").DefaultView

然后,修改一些datagrid中的数据,按一个按钮:再执行:
Dim cb As New OleDbCommandBuilder(da)
ds.AcceptChanges()
da.Update(ds, "t")
messagebox.show("hi")

其中,ds和da均为窗体级变量.
消息框是出来了,但是就是没有更新到数据库中,在ds通过rowfilter查询的时候,显示的倒是修改以后的数据.程序执行也没有提示错误.
...全文
41 20 打赏 收藏 转发到动态 举报
写回复
用AI写文章
20 条回复
切换为时间正序
请发表友善的回复…
发表回复
xydyh 2003-09-24
  • 打赏
  • 举报
回复
光是在datagrid 里修改数据是不行的,还要用语句修改dataset,之后再调用OleDbCommandBuilder,然后调用update.
你应该是少了修改dataset 的步骤!
qqwqq 2003-09-22
  • 打赏
  • 举报
回复
update 之后,再重新绑定
wisecloud 2003-09-19
  • 打赏
  • 举报
回复
应该去掉ds.AcceptChanges()
nakhi 2003-09-19
  • 打赏
  • 举报
回复
回复:rock, 不是我拧,这个问题非常奇怪,因为我考了人家的例子,居然都无法运行,我还是想专专牛角尖,把这个问题搞清楚, 至于desinger,只是帮助写出代码的工具.

回复:snow
你理解错了,修改当然是通过Datagrid来修改,现在我遇到了一个OledbDataAdpater.update的问题,所以把问题简化了,先通过="bill"这么来修改,看能否update.
snow66 2003-09-19
  • 打赏
  • 举报
回复
不用通过语句修改,直接在datagrid中修改就行了,去掉“bill”那句。
rock29 2003-09-19
  • 打赏
  • 举报
回复
nakhi你为什么那么拧?你就在设计界面建一个adapter,让程序生成语句,以后或者基于这个adapter写程序,或者copy相应的insert/del/update语句到代码中更新不行吗?
我老碰到这种问题,我认为net的cb自动生成的有问题.
nakhi 2003-09-19
  • 打赏
  • 举报
回复
回复楼上:还是不行:SUB如下:
----------------
Dim ds As New DataSet
Dim da As New OleDbDataAdapter("select * from files", "Provider=Microsoft.Jet.OLEDB.4.0;data source= ../filer.mdb")
Dim cb As New OleDbCommandBuilder(da)
da.Fill(ds)
ds.Tables(0).Rows(1).Item(2) = "bill"
da.Update(ds)
MessageBox.Show("hi")
这个时候,如果不执行update,程序正常
snow66 2003-09-19
  • 打赏
  • 举报
回复
只有一个表吗?那你试一下不用名字,用ds.tables(0)来替代。

da.Fill(ds)
dg.DataSource = ds.Tables(0).DefaultView

da.Update(ds)

nakhi 2003-09-19
  • 打赏
  • 举报
回复
回复小可:试了,还是不行:
Dim ds As New DataSet
Dim da As New OleDbDataAdapter("select id,title,key,location from files", "Provider=Microsoft.Jet.OLEDB.4.0;data source= ../filer.mdb")
Dim cb As New OleDbCommandBuilder(da)
da.Fill(ds, "users")
ds.Tables("users").Rows(1).Item(2) = "bill"
dg.DataSource = ds.Tables("users")
Dim ds1 As New DataSet
ds1 = ds.GetChanges()
ds1 = ds.GetChanges(DataRowState.Modified)
da.Update(ds1.Tables("users"))
MessageBox.Show("hi")

还是和原来一样的问题,如果不执行update这一行,则程序没有任何问题
nakhi 2003-09-19
  • 打赏
  • 举报
回复
回复楼上:
T是自己把表灌到ds中起的名字:
da = New OleDbDataAdapter("select * from files", cnstring)
ds = New DataSet
da.Fill(ds, "t")
代码全部都是自己写的,没有使用Designer


kexian 2003-09-19
  • 打赏
  • 举报
回复
dim mydatasetchanges as new dataset()
mydatasetchanges=ds2.getchanges()
mydatasetchanges=ds2.getchanges(datarowstate.modified)
objadapter.update(mydatasetchanges)
用这种方法试试
snow66 2003-09-19
  • 打赏
  • 举报
回复
你的“t”是程序中定义的表,还是在设计界面中定义的?如果“t”没问题,通过以下的步骤应该是可以的:

Dim cb As New OleDbCommandBuilder(da)
da.Update(ds, "t")
ds.AcceptChanges()
messagebox.show("hi")
nakhi 2003-09-19
  • 打赏
  • 举报
回复
回复楼上几位:去掉AcceptChanges还是不行
sub
Dim cb As New OleDbCommandBuilder(da)
da.Update(ds, "t")
'ds.AcceptChanges()
MessageBox.Show("OK")
end sub

在我举的例子中
objConn.Open()
Dim ds2 As DataSet = New DataSet
Dim objAdapter As New OleDbDataAdapter("SELECT * FROM files", objConn)
Dim objCmdBld As New OleDbCommandBuilder(objAdapter)
objCmdBld.RefreshSchema()
objAdapter.Fill(ds2, "users")
Dim drow As DataRow
ds2.Tables("users").Rows(1).Item(2) = "bill"
dg.DataSource = ds2.Tables("users")
------ objAdapter.Update(ds2, "users")-------------
MessageBox.Show("hi")
没有AcceptChanges,但是还是无法运行.
jsfeiyu 2003-09-18
  • 打赏
  • 举报
回复
ds.AcceptChanges()
da.Update(ds, "t")
先后顺序反了!
southdoor 2003-09-18
  • 打赏
  • 举报
回复
同意楼上的。ds接受更改后,对于数据库来说就没有更改了。
zhumb 2003-09-18
  • 打赏
  • 举报
回复
把ds.AcceptChanges()去掉看看
nakhi 2003-09-18
  • 打赏
  • 举报
回复
我找了一个例子:
Dim objConn As New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=../filer.mdb")
objConn.Open()
Dim ds2 As DataSet = New DataSet
Dim objAdapter As New OleDbDataAdapter("SELECT * FROM files", objConn)
Dim objCmdBld As New OleDbCommandBuilder(objAdapter)
objCmdBld.RefreshSchema()
objAdapter.Fill(ds2, "users")
Dim drow As DataRow
ds2.Tables("users").Rows(1).Item(2) = "bill"
dg.DataSource = ds2.Tables("users")
------ objAdapter.Update(ds2, "users")-------------
MessageBox.Show("hi")

其中,划线的这一行不运行,程序正常,它一运行,则出现错误:
未处理的“System.Data.OleDb.OleDbException”类型的异常出现在 system.data.dll 中。

不知道是哪儿出了问题了,files这个表是有主键的
rock29 2003-09-18
  • 打赏
  • 举报
回复
呜呜,我的就没问题,要不这样吧:
Dim cb As New OleDbCommandBuilder(da)
cb.RefreshSchema()
放在da.Fill(ds, "t")之前,不要dg.DataSource = ds.Tables("t").DefaultView而改成
dg.DataSource = ds.Tables("t") (似乎没关系)
看看,如果还不行,你就在设计界面建一个adapter,让程序生成语句,以后或者基于这个adapter写程序,或者copy相应的insert/del/update语句到代码中更新
nakhi 2003-09-18
  • 打赏
  • 举报
回复
加了,还是不行
Dim cb As New OleDbCommandBuilder(da)
cb.RefreshSchema()
da.UpdateCommand = cb.GetUpdateCommand
ds.AcceptChanges()
da.Update(ds, "t")

我刚才查询了一下过去的帖子,如果数据库不设主键的时候会有问题,但是我的Access数据库表中已经设置了主键, 而且程序执行是正常的,就是打开Access一看,没有更新!
rock29 2003-09-18
  • 打赏
  • 举报
回复
差一句:
cb.RefreshSchema()
net的最近面试经典试题ASP.NET面试题集合 1. 简述 private、 protected、 public、 internal 修饰符的访问权限。 答 . private : 私有成员, 在类的内部才可以访问。 protected : 保护成员,该类内部和继承类可以访问。 public : 公共成员,完全公开,没有访问限制。 internal: 在同一命名空间内可以访问。 2 .列举ASP.NET 页面之间传递值的几种方式。 答. 1.使用QueryString, 如....?id=1; response. Redirect().... 2.使用Session变量 3.使用Server.Transfer 3. 一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。 答:public class MainClass { public static void Main() { Console.WriteLine(Foo(30)); } public static int Foo(int i) { if (i 0 && i <= 2) return 1; else return Foo(i -1) + Foo(i - 2); } } 4.C#的委托是什么?事件是不是一种委托? 答 : 委托可以把一个方法作为参数代入另一个方法。 委托可以理解为指向一个函数的引用。 是,是一种特殊的委托 5.override与重载的区别 答 : override 与重载的区别。重载是方法的名称相同。参数或参数类型不同,进行多次重载以适应不同的需要 Override 是进行基类函数的重写。为了适应需要。 6.如果在一个B/S结构的系统需要传递变量值,但是又不能使用Session、Cookie、Application,您有几种方法进行处理? 答 : this.Server.Transfer 7.请编程遍历页面上所有TextBox控件并给它赋值为string.Empty? 答: foreach (System.Windows.Forms.Control control in this.Controls) { if (control is System.Windows.Forms.TextBox) { System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox)control ; tb.Text = String.Empty ; } } 8.请编程实现一个冒泡排序算法? 答: int [] array = new int ; int temp = 0 ; for (int i = 0 ; i < array.Length - 1 ; i++) { for (int j = i + 1 ; j < array.Length ; j++) { if (array[j] < array) { temp = array ; array = array[j] ; array[j] = temp ; } } } 9.描述一下C#索引器的实现过程,是否只能根据数字进行索引? 答:不是。可以用任意类型。 10.求以下表达式的值,写出您想到的一种或几种实现方法: 1-2+3-4+……+m [Page] 答: int Num = this.TextBox1.Text.ToString() ; int Sum = 0 ; for (int i = 0 ; i < Num + 1 ; i++) { if((i%2) == 1) { Sum += i ; } else { Sum = Sum - I ; } } System.Console.WriteLine(Sum.ToString()); System.Console.ReadLine() ; 11.用.net做B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为什么要这样分层? 答:一般为3层 数据访问层,业务层,表示层。 数据访问层对数据库进行增删查改。 业务层一般分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。 表示层为了与用户交互例如用户添加表单。 优点: 分工明确,条理清晰,易于调试,而且具有可扩展性。 缺点: 增加成本。 12.在下面的例子里 using Sy

16,555

社区成员

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

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