一个在ASP.NET中利用服务器控件GridView实现数据增删改查的例子

备注:这是我辅导的一个项目开发组的一个例子,用文章的方式分享出来,给更多的朋友参考。其实我们这几年的项目中,都不怎么使用服务器控件的形式了,而是更多的采用MVC这种开发模式。但是,如果项目的历史背景是用服务器控件的,也不妨继续沿用,以免变动太大,对项目的整体开发不利。

很多企业业务程序的页面,其实本质上都是对数据的操作,诸如增加、删除、修改和查询(简称:增删改查),如果有可能在一个页面中完整地实现(不需要几个页面转来转去),对于用户来说可能体验较好。

ASP.NET在2.0中开始提供多种数据控件,并且采用了模板的机制,使得我们上面的需求变得可能。今天要讲的就是号称ASP.NET中最复杂的控件:GridView的使用。它可以完整实现增删改查。

imageimageimageimage

 

页面:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="WebApplicationSample.Default" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>

</head>
<body>
    <form id="form1" runat="server">
        <div>
            <asp:GridView ID="gvData" runat="server" OnRowDeleting="gvData_RowDeleting" OnRowUpdating="gvData_RowUpdating" OnRowCancelingEdit="gvData_RowCancelingEdit" OnRowEditing="gvData_RowEditing" AutoGenerateColumns="true" AutoGenerateDeleteButton="true" AutoGenerateEditButton="true">

               <%--<Columns>
                    <asp:CommandField HeaderText="操作" UpdateText="保存" CancelText="取消" DeleteText="删除" ShowDeleteButton="true" ShowEditButton="true" EditText="编辑" />
                </Columns>--%>
            </asp:GridView>

            <asp:Button ID="btAddNew" runat="server" Text="添加新记录" OnClick="btAddNew_Click" />
        </div>
    </form>

    

    <script>
        //这里为所有删除按钮都处理一个事件,请用户确认
        var links = document.links;//获取所有的链接
        for (var i in links) {//循环他们
            var a = links[i];//取得当前这个链接
            if (a.text == "Delete" || a.text=="删除") {//如果是删除按钮的话
                var o = a.href;//获取这个链接的地址(默认会生成一个执行javascript的地址的)

                a.href = "#";//将这个地址删除掉,就是不要让他执行默认的行为
                a.addEventListener("click", function () {//添加一个新的事件注册
                    var result = window.confirm("你是否真的要删除?");//向用户确认是否要删除
                    if (result == true)//如果用户确定
                        eval(o);//执行原先默认的那个方法(去服务器删除数据)
                    return false;
                });
            }
        }
    </script>
</body>
</html>

 

代码:

using System;
using System.Collections.Generic;
using System.Web.UI.WebControls;

namespace WebApplicationSample
{


    /// <summary>
    /// 这个实例主要演示了如何使用GridView进行数据的增、删、改、查。
    /// 更多有关于该控件的知识,可以参考 http://msdn.microsoft.com/zh-cn/library/vstudio/system.web.ui.webcontrols.gridview.aspx (请仔细阅读)
    /// </summary>
    public partial class Default : System.Web.UI.Page
    {
        /// <summary>
        /// 这是我们定义的一个业务实体类,用来保存界面上的列表数据,为了保存,必须支持序列化
        /// </summary>
        [Serializable]
        public class Employee
        {
            public string FirstName { get; set; }
            public string LastName { get; set; }
        }


        private List<Employee> data = new List<Employee>();//这是用来保存那个列表数据的字段
        /// <summary>
        /// 重写这个方法来保存视图状态。因为每次页面刷新的时候,默认情况下,data都会被清空,如果希望在多次回发的过程中保存数据,则重写该方法
        /// </summary>
        /// <returns></returns>
        protected override object SaveViewState()
        {
            var obj = new object[] { base.SaveViewState(), data };
            return obj;
        }
        /// <summary>
        /// 重写该方法,是与上面这个方法配套,在回发回来之后加载并还原
        /// </summary>
        /// <param name="savedState"></param>
        protected override void LoadViewState(object savedState)
        {
            var obj = savedState as object[];

            base.LoadViewState(obj[0]);
            data = obj[1] as List<Employee>;
        }
        /// <summary>
        /// 页面初始化的时候执行该代码
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {//这里只是一个示例,默认给页面添加一个初始的员工,实际在做的时候,可以不加
                data = new List<Employee>(){
                    new Employee(){FirstName ="ares",LastName ="chen"}
                };

                gvData.DataSource = data;
                gvData.DataBind();
            }
        }


        /// <summary>
        /// 添加新的员工时执行该代码
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void btAddNew_Click(object sender, EventArgs e)
        {
            data.Add(new Employee());//创建一个空的对象
            gvData.DataSource = data;//设置数据源
            gvData.EditIndex = data.Count - 1;//设置当前这个对象为编辑状态
            gvData.DataBind();//绑定数据

        }

        /// <summary>
        /// 当用户决定要删除某一行数据时执行该代码
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void gvData_RowDeleting(object sender, GridViewDeleteEventArgs e)
        {
            //删除某一行
            data.RemoveAt(e.RowIndex);
            gvData.DataSource = data;
            gvData.EditIndex = -1;
            gvData.DataBind();
        }
        /// <summary>
        /// 当用户要保存修改时执行该代码
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void gvData_RowUpdating(object sender, GridViewUpdateEventArgs e)
        {
            var index = e.RowIndex;//获取当前编辑行当索引号
            var row = gvData.Rows[index];//获取当前用户编辑的这一行

            var firstName = (row.Cells[1].Controls[0] as TextBox).Text;//获取用户输入的数据
            var lastName = (row.Cells[2].Controls[0] as TextBox).Text;//获取用户输入的数据


            var emp = data[index];//找到这个对象
            emp.FirstName = firstName;
            emp.LastName = lastName;

            gvData.DataSource = data;
            gvData.EditIndex = -1;//退出编辑状态
            gvData.DataBind();
        }
        /// <summary>
        /// 当用户要取消编辑的时候
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void gvData_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
        {
            gvData.DataSource = data;
            gvData.EditIndex = -1;
            gvData.DataBind();
        }
        /// <summary>
        /// 当用户要进行编辑的时候
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void gvData_RowEditing(object sender, GridViewEditEventArgs e)
        {
            gvData.DataSource = data;
            gvData.EditIndex = e.NewEditIndex;
            gvData.DataBind();
        }
    }
}
分类:  ASP.NET MVC
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于一个简单的增删改查操作,我们可以使用ASP.NET Web Forms和SQL Server数据实现。下面是一个示例代码,可以实现一个学生信息的增删改查功能。 首先,我们需要创建一个数据库表,用于存储学生信息。下面是一个示例表结构: ``` CREATE TABLE Students ( ID INT PRIMARY KEY, Name VARCHAR(50), Gender VARCHAR(10), Age INT, Class VARCHAR(50) ) ``` 接下来,我们创建一个ASP.NET Web Forms网站,并添加一个Web Form页面。在页面上,我们可以添加一些控件,用于实现增删改查功能,例如TextBox、Button、GridView等。 在页面的代码后端,我们可以使用ADO.NET连接到数据库,并编写一些方法,用于实现增删改查操作。下面是一个示例代码: ``` public partial class Students : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) // 页面初次加载时,绑定GridView数据 { BindGrid(); } } // 绑定GridView数据 protected void BindGrid() { string connectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString; using (SqlConnection conn = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand("SELECT * FROM Students", conn); SqlDataAdapter da = new SqlDataAdapter(cmd); DataTable dt = new DataTable(); da.Fill(dt); GridView1.DataSource = dt; GridView1.DataBind(); } } // 添加学生信息 protected void btnAdd_Click(object sender, EventArgs e) { string connectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString; using (SqlConnection conn = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand("INSERT INTO Students (ID, Name, Gender, Age, Class) VALUES (@ID, @Name, @Gender, @Age, @Class)", conn); cmd.Parameters.AddWithValue("@ID", txtID.Text); cmd.Parameters.AddWithValue("@Name", txtName.Text); cmd.Parameters.AddWithValue("@Gender", ddlGender.SelectedValue); cmd.Parameters.AddWithValue("@Age", txtAge.Text); cmd.Parameters.AddWithValue("@Class", txtClass.Text); conn.Open(); cmd.ExecuteNonQuery(); conn.Close(); BindGrid(); // 添加完成后,重新绑定GridView数据 } } // 修改学生信息 protected void btnUpdate_Click(object sender, EventArgs e) { string connectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString; using (SqlConnection conn = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand("UPDATE Students SET Name=@Name, Gender=@Gender, Age=@Age, Class=@Class WHERE ID=@ID", conn); cmd.Parameters.AddWithValue("@ID", txtID.Text); cmd.Parameters.AddWithValue("@Name", txtName.Text); cmd.Parameters.AddWithValue("@Gender", ddlGender.SelectedValue); cmd.Parameters.AddWithValue("@Age", txtAge.Text); cmd.Parameters.AddWithValue("@Class", txtClass.Text); conn.Open(); cmd.ExecuteNonQuery(); conn.Close(); BindGrid(); // 修改完成后,重新绑定GridView数据 } } // 删除学生信息 protected void btnDelete_Click(object sender, EventArgs e) { string connectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString; using (SqlConnection conn = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand("DELETE FROM Students WHERE ID=@ID", conn); cmd.Parameters.AddWithValue("@ID", txtID.Text); conn.Open(); cmd.ExecuteNonQuery(); conn.Close(); BindGrid(); // 删除完成后,重新绑定GridView数据 } } // 选GridView的行时,将数据显示到文本框和下拉框 protected void GridView1_SelectedIndexChanged(object sender, EventArgs e) { GridViewRow row = GridView1.SelectedRow; txtID.Text = row.Cells[1].Text; txtName.Text = row.Cells[2].Text; ddlGender.SelectedValue = row.Cells[3].Text; txtAge.Text = row.Cells[4].Text; txtClass.Text = row.Cells[5].Text; } } ``` 在上面的代码,我们使用了ADO.NET的SqlCommand和SqlDataAdapter类,通过SQL语句实现了学生信息的增删改查操作。在页面的前端,我们可以使用ASP.NET控件实现界面的布局和交互,例如TextBox、Button、DropDownList、GridView等。 在页面的配置文件web.config,我们需要添加一个连接字符串,用于连接到数据库。例如: ``` <connectionStrings> <add name="ConnectionString" connectionString="Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\Database.mdf;Integrated Security=True" providerName="System.Data.SqlClient" /> </connectionStrings> ``` 在上面的代码,我们使用了本地的SQL Server Express数据库,并将其作为本地数据库文件Database.mdf附加到应用程序的App_Data目录下。这样,我们就可以在ASP.NET应用程序访问该数据库了。 最后,我们需要在ASP.NET Web Forms应用程序的根目录下创建一个Database.mdf文件,并在其创建一个名为Students的表,用于存储学生信息。这样,我们就完成了一个简单的增删改查操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值