您的位置: 首页 > 技术文档 > 网络编程 > 用 DataSet 对象更新数据
数据结构与算法(C#实现) 回到列表 JRun+dw2k4 快速上手jsp开发
 用 DataSet 对象更新数据

作者:planRED 时间: 2004-03-27 文档类型:原创 来自:蓝色理想

作者:Name: planRED
邮件:planred#163.com

http://api.533.net/ 这个是我新做的一个小站,宗旨为“beginner to beginner”,因为我也是初学者:) 里面的“心得体会” 都是我自己写的。

大家知道,DataSet保存的数据是位于服务器内存里面的原数据库的“副本”。所以用DataSet更新数据的过程就是先对“副本”进行更新,然后在将“原本”更新,按照我的理解就是把“原本”覆盖掉。具体到过程,首先是要找到需要更新的行,然后赋新值,最后更新原数据库。

要找到需要修改的行,比较方便的做法就是根据记录中的某个值进行查找,这样比用“列号”“行号”什么的方便多了。要做到这一点,首先就是要给数据库指定一个主键,然后即可按照主键进行查找。要注意的是这个主键必须要是在程序中指定的,并且这个主键不一定和你数据库原来有的主键一样。

然后就是最后的更新,当然是用DataAdapter的Update()方法借助CommandBuilder来实现,要注意的是,如果你的数据库一开始没有定义主键,那进行更新的时候会出错,返回的错误将是“对于不返回任何键列信息的 SelectCommand 不支持 UpdateCommand 的动态 SQL 生成。”这是因为我们用的Update()实际上是通过CommandBuilder动态生成sql语句,然后才进行的数据库操作。但如果你在一开始创建DataAdapter时的那个sql语句没有包含有主键的列的话,那CommandBuilder将不会发生作用。这一点是必须要牢记的。

说了这么多,如果有不明白的就看下面的程序,这个是我练习时写的,里面有一些个人的设定,比如记录名什么的,相信大家一看就明白。

代码拷贝框

[Ctrl+A 全部选择 然后拷贝]

出处:蓝色理想
责任编辑:蓝色

◎进入论坛网络编程版块参加讨论

作者文章
[asp.net]扩展Forms验证
.net 用户控件(使用缓存)
用 DataSet 对象更新数据
热门搜索:CSS Fireworks 设计比赛 网页制作 web标准 用户体验 UE photoshop Dreamweaver Studio8 Flash 手绘 CG
站点最新 站点最新列表
全兼容的纯CSS级联菜单要点浅析
CSS Sprites 图片整合技术
雅安,一场中式旅行
热烈祝贺"醒狮杯"圆满结束
菊花宝典大赏大奖教程《阳台》
交互设计师怎样和产品团队合作
Photoshop打造个性潮流音乐海报
简单解读面包屑
CSS盒模型
Apple与Microsoft网站可用性研究
栏目最新 栏目最新列表
safari 4 新特性
Photoshop制作精美高光流线字
IE下img多余5像素空白解决方法
XHTML1.0与HTML兼容指引16条
JavaScript优化细节
全兼容的纯CSS级联菜单要点浅析
CSS Sprites 图片整合技术
Photoshop打造个性潮流音乐海报
CSS盒模型
45度地图编辑器及游戏开发心得

蓝色理想版权申明:除部分特别声明不要转载,或者授权我站独家播发的文章外,大家可以自由转载我站点的原创文章,但原作者和来自我站的链接必须保留(非我站原创的,按照原来自一节,自行链接)。文章版权归我站和作者共有。

转载要求:转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印,亦不能抹去我站点水印。

特别注意:本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有,文章若有侵犯作者版权,请与我们联系,我们将立即删除修改。

本文现有 3 条评论 暂时没有人参与评分


zkxp Publish at 2006-1-11 16:52:38
这样一次把全部数据读入查找是否有不陀
DataRow dr=dt.Rows.Find(ids)这里建立了个DataRow对象获取修改值是否更新回DataSet了呢.
我的没有find方法结果不能更新.
        public void UpDateRowTo(string Table, string Condition)
        {
            objCmd = new SqlCommand("select top 1 * from ["+ Table +"] where "+ Condition, objConn);
            objAdp = new SqlDataAdapter(objCmd);
            objDst = new DataSet();
            objAdp.Fill(objDst, "theTable");
            //objTbl = objDst.Tables[0];
            //Row = objTbl.Rows[0];
        }
        public void DoUpDate(bool WithFree)
        {
            if(WithFree)
            {
                DoUpDate();
                Free();
            }
        }
        public void DoUpDate()
        {
            
            SqlCommandBuilder objCbd = new SqlCommandBuilder(objAdp);
            objCbd.GetUpdateCommand();
            objAdp.Update(objDst, "theTable");
        }
greenhill Publish at 2005-10-30 13:03:33
推荐Asp.net DataGrid第三方控件:SmartGrid for Asp.Net,神农氏软件开发的,国产控件,值得研究一下!
211.97.5.49 Publish at 2004-3-29 10:57:56
so confuse!
您的评论
用户名:  口令:
说明:输入正确的用户名和密码才能参与评论。如果您不是本站会员,你可以注册 为本站会员。
注意:文章中的链接、内容等需要修改的错误,请用报告错误,以利文档及时修改。
不评分 1 2 3 4 5
注意:请不要在评论中含与内容无关的广告链接,违者封ID
请您注意:
·不良评论请用报告管理员,以利管理员及时删除。
·尊重网上道德,遵守中华人民共和国的各项有关法律法规
·承担一切因您的行为而直接或间接导致的民事或刑事法律责任
·本站评论管理人员有权保留或删除其管辖评论中的任意内容
·您在本站发表的作品,本站有权在网站内转载或引用
·参与本评论即表明您已经阅读并接受上述条款
推荐文档 | 打印文档 | 评论文档 | 报告错误  
专业书推荐 更多内容
《Web标准设计》
《美工神话》
《Flash短片轻松学》
Illustrator CS3质感绘画表现技法
大师之路--Photoshop 完全解析
《用户体验要素》
HTML与CSS入门经典(第7版)
作品集 更多内容

华硕(Asus)手机 Zt23 毕业设计。 毕业设计。 Purple Mobile GUI 华硕(Asus)手机 Zt23 毕业设计。 毕业设计。 华贸提案