DataGrid的多行提交

DataGrid的多行提交

尽管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);

              }            

         }

 

转载于:https://www.cnblogs.com/hzuIT/articles/472800.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111139.html原文链接:https://javaforall.net

(0)
上一篇 2021年7月23日 上午8:00
下一篇 2021年7月23日 上午9:00


相关推荐

  • 设计模式之抽象工厂模式代码示例

    设计模式之抽象工厂模式代码示例

    2021年7月9日
    103
  • win7-字符集-乱码问题

    win7-字符集-乱码问题win7显示中文乱码怎么办?   Unicode是一种在计算机上使用的字符编码。它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。但由于不同国家和地区采用的字符集不一致,很可能出现无法正常显示所有字符的情况,那么非Unicode选项作用就是在遇到这种情况时,把非Unicode编码字符按照你选择的语言进行显示(百度知道)。…

    2022年6月3日
    42
  • 【已解决】罗技K380蓝牙键盘可以连接电脑,但无法输入怎么办?[通俗易懂]

    【已解决】罗技K380蓝牙键盘可以连接电脑,但无法输入怎么办?[通俗易懂]【问题】罗技k380可以连接并正常使用平板、手机。电脑显示着已连接,但就是无法输入。之前是可以用的,最近需要频繁配对突然不能用了。网上的各种方法都不好使,问京东客服也解决不了准备申请售后。【解决方案】后来仔细看了下k380使用方法,发现Fn+F1可以重置键盘的蓝牙设备,于是在电脑删除了k380蓝牙设备后,在蓝牙键盘上进行了Fn+F1重置,最后进行重启配对就ok了。可能是频繁配对让键盘有了缓存错误了。

    2022年10月16日
    4
  • 关于前端项目经验

    关于前端项目经验按着套路的话来讲 一般的指标就是这样 项目名称项目描述具体职责 nbsp 当然 还可以更细化 国内的招聘站点 都有简历模板 填填空就可以了 也可以证明你在这些方面有造诣并且可以让人可以看的出的 demo 可以传到 github 之类的可在线预览的 列举几个站点 并注明参与了哪些部分 nbsp 学到了哪些知识 nbsp 首先项目经验一定要务实 因为基本是一定会被问到的 你在项目中的位置 上面有

    2026年3月26日
    2
  • ARM汇编基础详解

    ARM汇编基础详解ARM 汇编基础详解 1 GNU 汇编语法 2 Cortex A7 常用汇编指令 2 1 处理器内部数据传输指令 2 2 存储器访问指令 2 3 压栈和出栈指令 2 4 跳转指令 2 5 算术运算指令 2 6 逻辑运算指令我们在进行嵌入式 Linux 开发的时候是绝对要掌握基本的 ARM 汇编 因为 Cortex A 芯片一上电 SP 指针还没初始化 C 环境还没准备好 所以肯定不能运行 C 代码 必须先用汇编语言设置好 C 环境 比如初始化 DDR 设置 SP 指针等等 当汇编把 C 环境设置好了以后才可以运行 C 代码

    2026年3月20日
    3
  • 个人网站赚钱经营解密

    个人网站赚钱经营解密现在所有的网站都在考虑如何赚钱 个人网站也不例外 个人网站最开始的动机可能是出于兴趣或一种爱好 但时间一长 这些兴趣或爱好便为自己积累了许多资源 比如数量可观的访问量 当这些资源积累到一定程度的时候 商业意识比较敏感的个人网站站长便开始寻求开展电子商务 将自己手中的资源进行商业操作 从而 个人网站开始赚钱 当然 目前比较流行的个人网站赚钱方式可能更多的还是依赖于广告 但从目前个人网站的广告收入来看

    2026年3月26日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号