之前有分享过一个范例

[C#] ADO.NET #3 (GridView + SqlDataSource)完全手写、后置程序代码,兼论 SqlDataSource与UpdateParameter/DeleteParameter的用法

后来,在网络上找到的人,就开始大量地为「SqlDataSource小精灵」动手写程序

这并非我的原意。

我的意思是,透过手写的程序代码,让您知道 SqlDataSource「骨子里面」也是ADO.NET

但,网络上乱找范例,抄了就上.....这样的心态,我也帮不上忙。

https://www.youtube.com/watch?v=tnGqKV4F_Pk

................................................................................................................

前两天,有位读者询问「上集第十章的范例, GridView一次只能编辑(更改)、删除一笔记录,为何要用DataSet来做??」

因为.......我拿这个范例来 Demo DataSet的删除、分页、更新等等功能

不是「只能」这样做  Orz

所以,我把这个范例(ASP.NET专题实务 / 松岗出版。上集,第十章)

改用 SqlCommand + DataReader来做。

首先,画面上只有一个简单的 GridView

<asp:GridView ID="GridView1" runat="server"  PageSize="5" DataKeyNames="id"
            OnRowCancelingEdit="GridView1_RowCancelingEdit"
            OnRowDeleting="GridView1_RowDeleting" OnRowEditing="GridView1_RowEditing"
            OnRowUpdating="GridView1_RowUpdating">
            <Columns>
                <asp:CommandField ButtonType="Button" ShowEditButton="True" />
                <asp:CommandField ShowSelectButton="True" />
                <asp:CommandField ShowDeleteButton="True" />
            </Columns>
        </asp:GridView>

后置程序代码:

using System.Web.Configuration;
using System.Data.SqlClient;
using System.Data;
 
 
    protected void DBInit()   //====自己手写的程序代码, Datareader / SqlCommand ====(Start)
    {  
           // 透过 DataReader 来做分页,以前已经发表过了。
           // 请看下面文章& Youtube影片教学: 

[.NET 4.5]GridView自定义分页的新属性,AllowCustomPaging与 VirtualItemCount #2 范例 - DataReader +数据库分页

 
    }
 
 
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            DBInit();   //---只有[第一次]执行本程序,才会进入 if判别式内部。
            // 第一次执行本程序,请从「GridView 第一页(0)」看起。
        }
    }
 
 
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {   //----修改、更新
 
        //----因为前面有三个「功能键(编辑、选取、删除)」,所以Cells[ ]从零算起,需扣掉前三个功能键与 id字段。
        TextBox my_test_time, my_title, my_author;
 
        my_test_time = (TextBox)GridView1.Rows[e.RowIndex].Cells[4].Controls[0];   // 抓到「Text控件」。
        my_title = (TextBox)GridView1.Rows[e.RowIndex].Cells[5].Controls[0];
        my_author = (TextBox)GridView1.Rows[e.RowIndex].Cells[6].Controls[0];
 
        //=== DataReader的写法 ==========================================
        SqlConnection Conn = new SqlConnection("您自己的链接字符串,或是Web.Config里面的链接字符串");
        Conn.Open();  
        
        //== (2). 执行SQL指令。或是查询、捞取数据。
        SqlCommand cmd = new SqlCommand("update [test] set [test_time] = @test_time, [title] = @title, [author] = @author where [id] = @id", Conn);
        cmd.Parameters.AddWithValue("@test_time", Convert.ToDateTime(my_test_time.Text));
        cmd.Parameters.AddWithValue("@title", my_title.Text);
        cmd.Parameters.AddWithValue("@author", my_author.Text);
 
        cmd.Parameters.AddWithValue("@id", (int)GridView1.DataKeys[e.RowIndex].Value);
        //---- GridView1.DataKeys[e.RowIndex].Value 是指:「用户点选的那一列」数据,所对应的数据表「主键(Primary Key)值」。
 
        //== (3). 自由发挥。
        int RecordsAffected = cmd.ExecuteNonQuery();
        //Response.Write("执行 Update的SQL指令以后,影响了" + RecordsAffected + "列的纪录。)";
 
        //== (4). 释放资源、关闭数据库的链接。
        cmd.Cancel();
 
        if (Conn.State == ConnectionState.Open)   {
            Conn.Close();
            Conn.Dispose(); 
        }
        //==========================================================
 
 
        //----修改、更新完成!!离开「编辑」模式  ----
        GridView1.EditIndex = -1;
        DBInit();
    }
 
 
    //==============================================
    //== GridView的分页,无法搭配 DataReader。所以要自己写分页!
 
    //protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
    //{   //----分页 Start----
    //    GridView1.PageIndex = e.NewPageIndex;
    //    DBInit();
    //}
 
 
    //==============================================
    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {   //----编辑模式----
        GridView1.EditIndex = e.NewEditIndex;
        DBInit();
        //----画面上的GridView,已经事先设定好「DataKeyName」属性 = id ----
        //----所以编辑时,主键id 字段会自动变成「只读」----
    }
 
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {   //---离开「编辑」模式----
        GridView1.EditIndex = -1;
        DBInit();
    }
 
 
 
    protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {   //----删除一笔数据
 
        //=== DataReader的写法 ==========================================
        SqlConnection Conn = new SqlConnection("您自己的链接字符串,或是Web.Config里面的链接字符串");
        Conn.Open();   //---- 这时候才连结DB
 
        //== (2). 执行SQL指令。
        SqlCommand cmd = new SqlCommand("delete from [test] where [id] = @id", Conn);
        cmd.Parameters.AddWithValue("@id",(int)GridView1.DataKeys[e.RowIndex].Value);
 
        //== (3). 自由发挥。
        int RecordsAffected = cmd.ExecuteNonQuery();
 
        //== (4). 释放资源、关闭数据库的链接。
        cmd.Cancel();
        if (Conn.State == ConnectionState.Open)
        {
            Conn.Close();
            Conn.Dispose(); 
        }
        //==========================================================
 
        //----「删除」已经完成!!记得重新整理画面,重载资料----
        DBInit();
    }

这个范例的程序代码看来虽然多又杂

但拆解开来,不过是三大主题:

  • 大型控件的 CommandField & 对应的事件(事件里面的 e,是什么意思?)
  • .FindControl()方法与 .Controls
  • ADO.NET ( DataReader + DataSet / DataTable)

这三个主题要讲一整天的课

所以初学者看不懂,才是「正常的」!因为有很多学问要先搞懂。

对应的课程如下:

这也是七周课程里面的「第三天&第四天」重点!!

远距教学-- 大型控件完全解密+ADO.NET实战范例 (14hr)

相关文章&范例:

[习题]上集 Ch 14-4 (Repeater与 ListView版) -- 撰写ADO.NET DataReader的分页程序#2(搭配SQL指令 ROW_NUMBER)

[习题]上集 Ch 14-4 撰写ADO.NET DataReader的分页程序#3(搭配SQL 2012指令 OFFSET...FETCH)

[读书心得]资料分页的优化,以SQL 2012的 OFFSET-FETCH为例

[习题]上集 Ch 14-4 (Repeater与 ListView版) -- 撰写ADO.NET DataReader的分页程序#2(搭配SQL指令 ROW_NUMBER)

GridView自定义分页样式#1(以下拉式选单,DropDownList做分页)与分页样版(PagerTemplate)-- TopPagerRow与 BottomPagerRow属性

https://www.youtube.com/watch?v=oY7jd0ABXeM

................................................................................................................

这位外国朋友每一篇文章与范例,都贴心地附上 YouTube影片教学,实在令人佩服
推荐给大家。
 
相同范例,他改用 EF 来做 GridView CRUD --
 

ADO.NET #3-1 (GridView + DataReader + SqlCommand)完全手写Code Behind的更多相关文章

  1. ADO SQL手写分页

    //实现层 ---------------------------------------------------------分割线---------------------------------- ...

  2. 抓取GridView "编辑"模式下,TextBox修改后的数值

    [FAQ]抓取GridView "编辑"模式下,TextBox修改后的数值 -- ASP.NET专题实务「上集」Ch.10 抓取GridView "编辑"模式下 ...

  3. C#通用数据访问类库

    说明:此篇文章是给那些和我一样仍在使用ADO.NET访问数据库的.NET开发人员写的,因为某些原因,比如还在使用.NET3.0以下版本开发.NET应用或者所使用的数据库对ORM支持不是很好,或者是对O ...

  4. 017. ADO.NET Connection和command及DataReader

    ADO.NET主要包括Connection , command , DataReader, DataSet, DataAdapter5个对象, 通过这5个对象可以对数据库进行查询, 添加, 修改及删除 ...

  5. ADO.NET数据库编程

    ADO.NET数据库编程 1.ADO.NET的相关概念. Microsoft的新一代技术,是ADO组件的后继者. 主要目的是在.NET Framework平台存取数据. 提供一致的对象模型,可以存取和 ...

  6. ADO.Net知识总结

    (一)基础知识 ADO.NET: .NET中用来向数据库提交执行SQL语句的一堆类 本机访问直接"Windows验证",但是一般项目中都是单独的数据库服务器,程序在另外一台电脑上连 ...

  7. ADO.NET基础笔记

    ADO.NET 程序要和数据库交互要通过ADO.NET进行,通过ADO.Net就能在程序中执行SQL了. ADO.Net中提供了对各种不同的数据库的统一操作接口. 连接字符串: 程序通过连接字符串指定 ...

  8. ADO.NET学习笔记(1)

    ADO.Net是.Net框架中为数据库的访问而封装的一个库.通过这个库我们可以简单便捷的访问数据库,并对数据库进行一些增删改查的操作,目前ADO.Net支持四种主流的数据库,分别是SQL.OLE DB ...

  9. ADO.NET之一:连接层

    ADO.NET大部分由System.Data.dll核心程序集来表示. ADO.NET类库有三种完全不听的方式来实现数据访问:连接式.断开式和通过Entity框架.连接式就是会一直占用网络资源,断开式 ...

随机推荐

  1. Window 7 安装Docker toolbox , 启动terminal时遇到的小问题

    参考:http://blog.csdn.net/tina_ttl/article/details/51372604 参考前面网页成功安装后打开terminal,出现下面问题: Looks like s ...

  2. Typography 文字排版

    标签的语义 1. 含语义的标签 2. 不含语义, 但是具有样式的class <h1></h1> <p class="h1"></p> ...

  3. MYSQL MYSQLI PDO

    PHP的MySQL扩展(优缺点) 设计开发允许PHP应用与MySQL数据库交互的早期扩展.mysql扩展提供了一个面向过程 的接口: 并且是针对MySQL4.1.3或更早版本设计的.因此,这个扩展虽然 ...

  4. Docker:容器与主机时间不同步问题解决

    在Docker容器运行后,可能会发现容器时间与宿主机时间不一致,一般会差8个小时.这样会造成在容器中运行的web程序打出的日志时间与实际时间不一致,如果web程序中有定时任务也会造成影响等,需要对宿主 ...

  5. CodeForces 137C【贪心+优先队列】

    这种区间的贪心好像都出"烂"了? 不过还是想写一下... 先按照区间左端点排序一下,然后搞个优先队列维护当前最小的右端点. #include <bits/stdc++.h&g ...

  6. P2939 [USACO09FEB]改造路Revamping Trails(分层图最短路)

    传送门 完了我好像连分层图最短路都不会了……果然还是太菜了…… 具体来说就是记录一个步数表示免费了几条边,在dijkstra的时候以步数为第一关键字,距离为第二关键字.枚举边的时候分别枚举免不免费下一 ...

  7. linux网络配置详解

    一:相关网络配置的文件 1.网卡名配置相关文件 网卡名命名规则文件: /etc/udev/rules.d/70-persistent-net.rules # PCI device 0x8086:0x1 ...

  8. Codeforces Round #501 (Div. 3) 1015A Points in Segments (前缀和)

    A. Points in Segments time limit per test 1 second memory limit per test 256 megabytes input standar ...

  9. day20模块作业

    1.模块化作业 1.回顾文件递归遍历. 默写一遍. 入口在: 当文件是个文件夹的时候 出口在: 文件是一个文件 2.计算时间差(用户输入起始时间和结束时间. 计算时间差(小时), 例如, 用户输入20 ...

  10. [题解](排列组合)luogu_P3223排队

    把老师和女生插到男生中间,先对男生排列:A(n,n),然后把老师插到n+1个空里:A(n+1,2),然后放入女生:A(n+3,m) 但是少考虑了老师之间由1个女生分开的情况,所以把三个人看作一个整体, ...