当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > asp.net 2.0中用GRIDVIEW插入新记录

ASP.NET
利用ASP.NET和AJAX解决手工拼接HTML问题
Asp.net关于动态输出服务器控件的应用
技巧/诀窍:在ASP.NET中重写URL
ASP.NET 自定义控件从入门到精通3
以Post方式向网页发送数据
ASP.NET实现数据采集
使用ASP.NET Image Generation生成图片缩略图及水印
ASP.NET安全问题--ASP.NET安全架构
反思软件系统与软件系统之间的集成交互问题
.Net实现程序的插件机制
作为ASP.NET开发人员必须养成的编程习惯
总结了一下ADO.NET数据库连接的相关知识
VB.NET中有用的通用对象列表
HTTP Error 503与.NET 3.5 SP1 X64
ASP.NET创建Web服务之使用事务
ASP.NET中基类Page_Load方法后执行原因分析
ASP.NET中让网页弹出窗口不再困难
改变.net网站的默认解决方案位置
.net垃圾回收和CLR 4.0对垃圾回收所做的改进之二
.net垃圾回收和CLR 4.0对垃圾回收所做的改进之一

ASP.NET 中的 asp.net 2.0中用GRIDVIEW插入新记录


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 153 ::
收藏到网摘: n/a

看了下国外某巨牛的BLOG,大概是讲asp.net 2.0中用GRIDVIEW插入新记录的,方法比较特别,但效果一般,故将程序转之,较为简单,不做解释等。

以下为引用的内容:
<%@ Page Language="C#" ClassName="Default_aspx" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">

<script runat="server">
  void CancelButton1_Click(object sender, EventArgs e)
  {

    GridView1.ShowFooter = false;

  }
  void AddButton1_Click(object sender, EventArgs e)
  {

    GridView1.ShowFooter = true;

  }

  void Button1_Click(object sender, EventArgs e)

  {
    
    TextBox customerID = GridView1.FooterRow.FindControl("CustomerIDTextBox") as TextBox;

    TextBox companyName = GridView1.FooterRow.FindControl("CompanyNameTextBox") as TextBox;

    DropDownList ContactTitle = GridView1.FooterRow.FindControl("ContactTitleDropDownList") as DropDownList;

    SqlDataSource1.InsertParameters["CustomerID"].DefaultValue = customerID.Text;

    SqlDataSource1.InsertParameters["CompanyName"].DefaultValue = companyName.Text;

    SqlDataSource1.InsertParameters["ContactTitle"].DefaultValue = ContactTitle.SelectedValue;

    SqlDataSource1.Insert();

  }


</script>

<html xmlns="http://www.w3.org/1999/xhtml" >

<head id="Head1" runat="server">

  <title>Untitled Page</title>

</head>

<body>

  <form id="form1" runat="server">

  <div>
  <asp:Button ID="AddButton1" runat="Server" Text="Add new Item" OnClick="AddButton1_Click" />


  <asp:GridView ID="GridView1" Runat="server" DataSourceID="SqlDataSource1" DataKeyNames="CustomerID"

      AutoGenerateColumns="False" ShowFooter="True">

      <Columns>

        <asp:TemplateField>

          <ItemTemplate>

            <asp:Label ID="CustomerIDLabel" Runat="Server"><%# Eval("CustomerID") %></asp:Label>

          </ItemTemplate>

          <FooterTemplate>

            <asp:TextBox ID="CustomerIDTextBox" Runat="server"></asp:TextBox>

          </FooterTemplate>

        </asp:TemplateField>

        <asp:TemplateField>

          <ItemTemplate>

            <asp:Label ID="CompanyNameLabel" Runat="Server"><%# Eval("CompanyName") %></asp:Label>

          </ItemTemplate>

          <FooterTemplate>

            <asp:TextBox ID="CompanyNameTextBox" Runat="server"></asp:TextBox>

          </FooterTemplate>

        </asp:TemplateField>

        <asp:TemplateField>

          <FooterTemplate>

            <asp:DropDownList ID="ContactTitleDropDownList" Runat="server" DataSourceID="SqlDataSource2" DataTextField="ContactTitle" DataValueField="ContactTitle">

            </asp:DropDownList>

            <asp:SqlDataSource ID="SqlDataSource2" Runat="server" SelectCommand="SELECT DISTINCT [ContactTitle] FROM [Customers]"

              ConnectionString="server=localhost;uid=sa;password=xxx;database=northwind">

            </asp:SqlDataSource>

            <asp:Button ID="Button1" Runat="server" Text="Add" OnClick="Button1_Click" />
 <asp:Button ID="CancelButton1" Runat="server" Text="Cancel" OnClick="CancelButton1_Click" />

          </FooterTemplate>

          <ItemTemplate>

            <asp:DropDownList ID="ContactTitleDropDown" SelectedValue='<%# Bind("ContactTitle") %>' Runat="Server" DataSourceID="SqlDataSource3" DataTextField="ContactTitle" DataValueField="ContactTitle" ></asp:DropDownList>

            <asp:SqlDataSource ID="SqlDataSource3" Runat="server" SelectCommand="SELECT DISTINCT [ContactTitle] FROM [Customers]"

              ConnectionString="server=localhost;uid=sa;password=xxx;database=northwind" EnableCaching="True">

            </asp:SqlDataSource>

          </ItemTemplate>

        </asp:TemplateField>

      </Columns>

    </asp:GridView>

    <asp:SqlDataSource ID="SqlDataSource1" Runat="server"

      InsertCommand="INSERT INTO [Customers] ([CustomerID], [CompanyName], [ContactTitle]) VALUES (@CustomerID, @CompanyName, @ContactTitle)"

      SelectCommand="SELECT [CustomerID], [CompanyName], [ContactTitle] FROM [Customers]"

      ConnectionString="server=localhost;uid=sa;password=xxxxx;database=northwind">

      <DeleteParameters>

        <asp:Parameter Type="String" Name="CustomerID"></asp:Parameter>

      </DeleteParameters>

      <UpdateParameters>

        <asp:Parameter Type="String" Name="CompanyName"></asp:Parameter>

        <asp:Parameter Type="String" Name="ContactTitle"></asp:Parameter>

        <asp:Parameter Type="String" Name="CustomerID"></asp:Parameter>

      </UpdateParameters>

      <InsertParameters>

        <asp:Parameter Type="String" Name="CustomerID"></asp:Parameter>

        <asp:Parameter Type="String" Name="CompanyName"></asp:Parameter>

        <asp:Parameter Type="String" Name="ContactTitle"></asp:Parameter>

      </InsertParameters>

    </asp:SqlDataSource>

  </div>

  </form>

</body>

</html>