转发器内的文本框值并保存

时间:2017-08-21 05:31:10

标签: c# asp.net sql-server sql-server-2008

我这里有一个代码,可以在搜索栏上获取一个交易号并在页面上显示。我还有2个文本框,其中客户将输入price付款和收据的或否。但是,我收到了错误

  

"对象引用未设置为实例..."

.ASPX

<form id="form1" runat="server">
<div>
<asp:Repeater ID="rptrCashierTable" runat="server">
    <ItemTemplate>
        <div>
            <h1 align="center">Transaction Number: <label><%# Eval("TXNNo") %></label>

         <h2>Name:<label><%# Eval("FName") %></label>
         <label><%# Eval("MName") %></label>
         <label><%# Eval("LName") %></label></h2>             
         <h2>Contact Number: <label><%# Eval("MOBILE") %></label></h2>
         <h2>Product Ordered: <label><%# Eval("PName") %></label></h2>
         <h2>Product ID:<label><%# Eval("ProductID") %></label></h2>
         <h2>Price: 
             <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox></h2>
         <h2>OR No.: 
             <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox></h2>
                <asp:Button ID="Button1" runat="server" Text="Submit" OnClick="btn_Update" />
        </div>
    </ItemTemplate>
</asp:Repeater>
</div>
</form>

.CS

public partial class TransactionDetails : System.Web.UI.Page
{
    SQLQuery sql = new SQLQuery();
    DataSet ds = new DataSet();

    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            BindCasierTable();
        }

    }
    private void BindCasierTable()
    {            
        string TransctID = Request.QueryString["TXNNo"];
        ds = sql.dsGetClientDetails(TransctID);

        rptrCashierTable.DataSource = ds;
        rptrCashierTable.DataBind();
    }

    protected void btn_Update(object sender, EventArgs e)
    {


        foreach (RepeaterItem item in rptrCashierTable.Items)
        {                           

            if (item.ItemType == ListItemType.Item)
            {
                var txtPrice = item.FindControl("TextBox1") as TextBox;
                var txtORNo = item.FindControl("TextBox2") as TextBox;
                string TXNNo = Request.QueryString["TXNNo"];
                ds = sql.dsAddPayment(txtPrice.Text, txtORNo.Text, TXNNo);
                txtPrice.Text = string.Empty;
                txtORNo.Text = string.Empty;
                BindCasierTable();
            }


        }
    }
}

我正在使用MSSQL 2008和存储过程。我只是想更新并将Price付费和OR号码放到各自的字段中。

1 个答案:

答案 0 :(得分:0)

该错误消息表示您正在分配具有空值的内容。我想这里会出现错误:

string TransctID = Request.QueryString["TXNNo"]

你应该先检查它是否为空:

if(Request.QueryString["TXNNo"]!=null)
{
 // make the assignation here
}