An Example of ASPNET Gridview CRUD

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Mobile_AjustmentVoucher.aspx.cs" Inherits="Mobile_AjustmentVoucher" EnableEventValidation="false" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <style type="text/css">
        .auto-style1 {
            position: absolute;
            top: -8px;
            left: 121px;
            z-index: 1;
        }
    </style>
</head>
<body>
    <form id="form1" runat="server" class="auto-style8">
        <asp:Label ID="Label1" runat="server" Text="Adj. Voucher No"></asp:Label>
        <br />
        <asp:TextBox ID="tb_adjustmentId" runat="server"></asp:TextBox>
        <br />
        <br />
        <div id="container">
            <asp:GridView ID="GridView1" runat="server" 
                AutoGenerateColumns="False" 
                OnRowCancelingEdit="GridView1_RowCancelingEdit" 
                OnRowDeleting="GridView1_RowDeleting" 
                OnRowEditing="GridView1_RowEditing" 
                OnRowUpdating="GridView1_RowUpdating"
                DataKeyNames = "itemId" >
            <Columns>
            <asp:BoundField DataField="itemId" HeaderText="itemId" ReadOnly="true"/>
            <asp:BoundField DataField="description" HeaderText="Description" ReadOnly="true" />
            <asp:BoundField DataField="adjustment" HeaderText="Adjustment" />
            <asp:BoundField DataField="remark" HeaderText="Reason" />
                <asp:CommandField HeaderText="Delete" ShowDeleteButton="True" ShowHeader="True" />
                <asp:CommandField HeaderText="Edit" ShowEditButton="True" ShowHeader="True" />
            </Columns>
            </asp:GridView>
        </div>
        <br />
        <br />

        <asp:Panel ID="Panel1" runat="server" CssClass="auto-style7">
            <asp:Label ID="lb_description" runat="server" Text="Description"></asp:Label>
            <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ADT9DB1ConnectionString %>" SelectCommand="SELECT [description] FROM [stationaryCatelogue]"></asp:SqlDataSource>
            <br />
            <asp:Label ID="lb_adjustemnt" runat="server" Text="Adjustment"></asp:Label>
            <asp:TextBox ID="tb_adjustment" runat="server" Text="0"></asp:TextBox>
            <br />
            <asp:Label ID="lb_mark" runat="server" Text="Reason"></asp:Label>
            <asp:TextBox ID="tb_mark" runat="server"></asp:TextBox>
            <br />
            <asp:DropDownList ID="ddl_description" runat="server" CssClass="auto-style1" DataSourceID="SqlDataSource1" DataTextField="description" DataValueField="description">
            </asp:DropDownList>
                <br />
            <asp:Button ID="bt_save" runat="server" OnClick="bt_save_Click" Text="Save" />
        </asp:Panel>
        <asp:Button ID="bt_add" runat="server" OnClick="bt_add_Click" Text="Add" />
        <br />
        <asp:Button ID="bt_calculatePrice" runat="server" CssClass="auto-style6" Text="calculate" OnClick="bt_calculatePrice_Click" />
        <br />
        <br />
        <br />
        <asp:Button ID="bt_submit" runat="server" Text="Submit for Authorisation" OnClick="bt_submit_Click" />
        <asp:TextBox ID="tb_totalPrice" runat="server" CssClass="auto-style4" ></asp:TextBox>
        <br />
        <br />
        <asp:TextBox ID="tb_test1" runat="server"></asp:TextBox>
    </form>
</body>
</html>

aspx.cs

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

public partial class Mobile_AjustmentVoucher : System.Web.UI.Page
{
    ADT9DB1Entities1 context;
    transactionList tl;
    transactionListItem tli;
    stationaryCatelogue sc;
    static HashSet<transactionListItem> adjustmentList;

    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            Panel1.Visible = false;
            adjustmentList = (HashSet<transactionListItem>)Application["adjustmentList"];
            bind();
        }
        context = new ADT9DB1Entities1();
        tl = new transactionList();
        tli = new transactionListItem();
        sc = new stationaryCatelogue();

        getAdjustmentId();
        tb_adjustmentId.Text = (string)Application["adjustmentId"];

        // display current itmem in the adjustmentList
        //bind();
    }

    public void bind()
    {
        GridView1.DataSource = adjustmentList;
        GridView1.DataBind();
    }

    public void getAdjustmentId()
    {
        if (Application ["adjustmentId"].Equals(""))
        {
            //create adjustmentId and the the table
            Application.Lock();
            Application["adjustmentId"] = "iav" + "/" + User.Identity.Name + "/" + DateTime.Now; ;
            Application.UnLock();

            tl.id = (string)Application["adjustmentId"];
            tl.type = "iav";
            context.transactionLists.Add(tl);
            context.SaveChanges();
        }
        tl.id = (string)Application["adjustmentId"];
    }

    protected void bt_submit_Click(object sender, EventArgs e)
    {
        saveToDatabse();

        //redirect
    }

    protected void bt_cancel_Click(object sender, EventArgs e)
    {
        clearModel();
        //redirect
    }

    public void clearModel()
    {
        adjustmentList = null;

        Application.Lock();
        Application ["adjustmentId"] = "";
        Application ["adjustmentList"] = "";
        Application.UnLock();
    }

    protected void bt_add_Click(object sender, EventArgs e)
    {
        Panel1.Visible = true;

    }

    public void clearInputs()
    {
        ddl_description.Text = null;
        tb_adjustment.Text = "0";
        tb_mark.Text = null;
    }


    public void fillTransactionItemsModel()
    {
        var q = context.stationaryCatelogues.Where(x => x.description == ddl_description.SelectedValue).FirstOrDefault();

        tli.transactionId = tl.id;
        tli.itemId = q.id.ToString();
        tli.finalQty = q.currentBalance + Convert.ToInt32(tb_adjustment.Text);
        tli.remark = tb_mark.Text.ToString();
        tli.description = ddl_description.SelectedValue;
        tli.adjustment = Convert.ToInt32(tb_adjustment.Text);

        adjustmentList.Add(tli);
    }


    protected void bt_save_Click(object sender, EventArgs e)
    {
        fillTransactionItemsModel();

        bind();
        //clear
        clearInputs();

        calculatePrice();
    }

    public double calculatePrice()
    {
        double totalPrice = 0;

        foreach (var item in adjustmentList)
        {
            sc = context.stationaryCatelogues.Where(x => x.id == item.itemId).FirstOrDefault();
            totalPrice += Convert.ToDouble(item.adjustment * sc.price1);
        }
        return totalPrice;
    }

    public void saveToDatabse()
    {
        //write to database
        tl.requestBy = User.Identity.Name;
        tl.requestDate = DateTime.Now;
        context.SaveChanges();

        int count = context.transactionListItems.Select(x => x.id).ToList().Last();
        foreach (transactionListItem item in adjustmentList)
        {
            item.id = count++;
            context.transactionListItems.Add(item);
            context.SaveChanges();
        }

        //clear adjustmentId session
        clearModel();
        
        ////redirect 
    }

    protected void bt_calculatePrice_Click(object sender, EventArgs e)
    {
        tb_totalPrice.Text = calculatePrice().ToString();

    }

    protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        string itemId = GridView1.DataKeys[e.RowIndex].Value.ToString();
        adjustmentList.RemoveWhere(x => x.itemId == itemId);
        bind();
    }

    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        //GridViewRow row = GridView1.Rows[e.RowIndex];
        ////TextBox adjustment = (TextBox)row.FindControl("adjustment");
        ////TextBox remark = (TextBox)row.FindControl("remark");
        //TextBox adjustment = (TextBox)row.Cells[0].Controls[0];
        //TextBox remark = (TextBox)row.Cells[1].Controls[0];

        string itemId = GridView1.DataKeys[e.RowIndex].Value.ToString();
        //read only
        //string description = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).Text.ToString().Trim();
        string adjustment = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[2].Controls[0])).Text.ToString().Trim();
        string remark = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).Text.ToString().Trim();

        //?
        //update in the adjustmentList
        transactionListItem q = adjustmentList.First(x => x.itemId == itemId);
        q.adjustment = Convert.ToInt32(adjustment);
        q.remark = remark;

        //tb_test1.Text = adjustment.ToString();
        tb_test1.Text = q.adjustment.ToString();


        GridView1.EditIndex = -1;

        bind();


    }

    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        bind();
    }

    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
    {
        GridView1.EditIndex = -1;
        bind();
    }
}

useful link

http://www.aspsnippets.com/Articles/Insert-Update-Edit-Delete-record-in-GridView-using-SqlDataSource-in-ASPNet.aspx

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,313评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,369评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,916评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,333评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,425评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,481评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,491评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,268评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,719评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,004评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,179评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,832评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,510评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,153评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,402评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,045评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,071评论 2 352

推荐阅读更多精彩内容