网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.GridViewRow可以任意位置单击引发.
.一种“您无权查看该网页”的原因.
.ASP.NET MasterPage 中图片路径的.
.把WebForm数据导出到Excel中 .
.爬虫如何抓取到Asp.Net中-doPost.
.cookies的丢失和中文乱码.
.Asp.net把UTF-8编码转换为GB2312.
.在Asp.net中调用异步方法-使用信.
.跳出封装剖析ASP.NET脚本回调的原.
.用 md5 加密数据库中的用户密码.
.保存图片流到数据库之后固定显示.
.在.NET中使用脚本引擎.
.使用JScript.NET创建asp.net页面.
.过滤ASP.NET输出HTML中的无用空格.
.Web导出Word需要添加头文件.
.实现在页面中单击按钮关闭页面.
.COOKIE问题.
.asp.net menu "Operation aborte.
.asp.net中一次更新DATAGRID中所有.
.Asp.net 2.0 Treeview 无限级无刷.

DataGrid的多行提交

发表日期:2006-8-10


尽管ASP.NET DataGrid是众所周知非常好的表格控件,不过,提起DataGrid的编辑功能,我们却不敢恭维了,就拿DataGrid的数据提交功能来说,的确存在很大的问题:在DataGrid中,每编辑一行就要提交一行,即所谓“单行编辑、单行提交”,这样的话,如果编辑的行数过多,不仅用户操作繁琐,还会造成对服务器的频繁访问,极大降低系统效率。

当然了,有一种借尸还魂的解决方法,那就是把所要编辑的内容转到其他的页中在TextBox中进行编辑。不过,仔细想想,这种方法难道不是自己在骗自己吗,还有在Grid中我们编辑的时候总不能老是用Tab键来实现Grid(TextBox)之间的跳转吧,如果响应回车事件,那么需要程序员浪费很大的精力来开发。

如何解决上述问题呢?下面我向大家推荐一个我正在使用的国产DataGrid:SmartGrid(天空软件站可以下载:http://www.skycn.com/soft/23547.html ),这个控件我已经用了好长的时间了,现在来同大家探讨一下SmartGrid的多行提交的方法:SmartGrid并没有DataGrid中的那些按钮列而是整个的表单只有一个提交按钮,无论你更改了一行或者是多行都可以一次性的提交,下面来随便看点例子:

实例:

上图中是一个比较好的编辑的例子,例子显示,你可以编辑多行也可以编辑一行,然后一起进行提交。

代码:

修改按钮的代码:

private void btonSave_Click(object sender, System.EventArgs e)

         {

              this.DataGrid1.ReadOnly = false;//进入编辑

              this.DataGrid1.AllowAdd = true;//允许添加

              this.DataGrid1.AllowDelete = true;//允许删除

         }

此段代码是smartgrid的独有的属性你可以设添加删除 编辑 的各种的功能

保存按钮的代码:
private void Button2_Click(object sender, System.EventArgs e)

         {

              DataTable t = (DataTable)this.SmartGrid1.DataSource;

              this.sqlDataAdapter1.Update(t);            

              t.Clear();

              this.sqlDataAdapter1.Fill(t);

              this.SmartGrid1.DataSource = t;

         }

这是整体的把数据提交到数据库中,这种做法适合大数据量的情况

还有一种是数据逐行的提交到服务器

代码:

private void btonSave_Click(object sender, System.EventArgs e)

         {            

              DataTable tb=(DataTable)this.SmartGrid1.DataSource;

              SqlParameter[] parameters=new SqlParameter[5];

              foreach(DataRow dr in tb.Rows)

              {

                   parameters[0]=new SqlParameter("@customerId",""+dr[1]+"");

                   parameters[1]=new SqlParameter("@companyName",""+dr[0]+"");

                   parameters[2]=new SqlParameter("@contactName",""+dr[2]+"");

                   parameters[3]=new SqlParameter("@contactTitle",""+dr[3]+"");

                   parameters[4]=new SqlParameter("@address",""+dr[4]+"");

                   //EamPd 是类Execute是执行存储过程的函数parameters是存储过程所需要的参数

                   EamPd.Execute("CreatLayer",parameters);

              }            

         }

上一篇:ASP.NET 2.0的异步页面刷新 人气:6674
下一篇:慎用url重写 人气:5971
浏览全部DataGrid的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐