没有重载的方法需要4个参数

时间:2016-08-26 15:41:08

标签: c# asp.net gridview

我正在尝试更新gridview。在这里,我使用了3层架构方法。

这是我的GridView。

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" CellPadding="4" DataKeyNames="ResllerID"
          ForeColor="#333333" GridLines="None" OnRowDeleting="DeleteRecord" EmptyDataText="There are no data records to display." 
        AllowPaging="True" AllowSorting="True" onrowediting="GridView1_RowEditing" onrowupdating="GridView1_RowUpdating"
        AutoGenerateDeleteButton="True" AutoGenerateEditButton="True" >
        <AlternatingRowStyle BackColor="White" />
        <Columns>
                <asp:TemplateField HeaderText="Reseller Name" SortExpression="ResellerName">  
                    <EditItemTemplate>  
                        <asp:TextBox ID="ResellerTextBox" runat="server" Text='<%# Bind("ResellerName") %>'></asp:TextBox>  
                    </EditItemTemplate>  
                    <ItemTemplate>  
                <asp:Label ID="Label1" runat="server" Text='<%# Bind("ResellerName") %>'></asp:Label>  
                    </ItemTemplate>  
                </asp:TemplateField>
                <asp:TemplateField HeaderText="Mobile Number" SortExpression="MobileNumber">  
                    <EditItemTemplate>  
                        <asp:TextBox ID="MobileTextBox" runat="server" Text='<%# Bind("MobileNumber") %>'></asp:TextBox>  
                    </EditItemTemplate>  
                    <ItemTemplate>  
                <asp:Label ID="Label2" runat="server" Text='<%# Bind("MobileNumber") %>'></asp:Label>
                  </ItemTemplate>  
                 </asp:TemplateField>

                  <asp:TemplateField HeaderText="Reference Number" SortExpression="ReferenceNumber">  
                    <EditItemTemplate>  
                        <asp:TextBox ID="ReferenceTextBox" runat="server" Text='<%# Bind("ReferenceNumber") %>'></asp:TextBox>  
                    </EditItemTemplate>  
                    <ItemTemplate>  
                <asp:Label ID="Label3" runat="server" Text='<%# Bind("ReferenceNumber") %>'></asp:Label>
                    </ItemTemplate>  
                </asp:TemplateField>

        </Columns>
        <FooterStyle BackColor="#990000" Font-Bold="True" ForeColor="White" />
        <HeaderStyle BackColor="#990000" Font-Bold="True" ForeColor="White" />
        <PagerStyle BackColor="#FFCC66" ForeColor="#333333" HorizontalAlign="Center" />
        <RowStyle BackColor="#FFFBD6" ForeColor="#333333" />
        <SelectedRowStyle BackColor="#FFCC66" Font-Bold="True" ForeColor="Navy" />
        <SortedAscendingCellStyle BackColor="#FDF5AC" />
        <SortedAscendingHeaderStyle BackColor="#4D0000" />
        <SortedDescendingCellStyle BackColor="#FCF6C0" />
        <SortedDescendingHeaderStyle BackColor="#820000" />
    </asp:GridView>

这是我的代码:我收到错误ResellerBL.UpdateReseller(resellerId,name.Text,mobileNumber.Text,referenceNumber.Text);它说没有重载的方法需要4个参数

protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridView1.EditIndex = e.NewEditIndex;
        GridView1.DataSource = ResellerBL.GetResellers();
        GridView1.DataBind();
    }

    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        int resellerId = Convert.ToInt32(GridView1.DataKeys[e.RowIndex].Value);
        TextBox name = (TextBox)GridView1.Rows[e.RowIndex].Cells[2].Controls[0];
        TextBox mobileNumber = (TextBox)GridView1.Rows[e.RowIndex].Cells[3].Controls[0];
        TextBox referenceNumber = (TextBox)GridView1.Rows[e.RowIndex].Cells[4].Controls[0];

        ResellerBL.UpdateReseller(resellerId, name.Text, mobileNumber.Text, referenceNumber.Text);

        GridView1.EditIndex = -1;
        GridView1.DataSource = ResellerBL.GetResellers();
        GridView1.DataBind();
    }

ResellerBL代码:

public static void UpdateReseller(Reseller reseller)
    {
        string query = "UPDATE [Resellers] SET [ResellerName] = @ResellerName, [ReferenceNumber] = @ReferenceNumber WHERE [ResellerID] = @ResellerID";
        SqlCommand cmd = new SqlCommand(query);

        cmd.Parameters.AddWithValue("@ResellerName", SqlDbType.Text).Value = reseller.ResellerName;
        cmd.Parameters.AddWithValue("@MobileNumber", SqlDbType.Text).Value = reseller.MobileNumber;
        cmd.Parameters.AddWithValue("@ReferenceNumber", SqlDbType.Text).Value = reseller.ReferenceNumber;

        cmd.Parameters.AddWithValue("@ResllerID", SqlDbType.Text).Value = reseller.ResllerID;

        DbUtility.UpdateDb(cmd);
    }

2 个答案:

答案 0 :(得分:1)

你用四个参数调用它:

ResellerBL.UpdateReseller(resellerId, name.Text, mobileNumber.Text, referenceNumber.Text);

但它只接受一个:

public static void UpdateReseller(Reseller reseller)

有两个选项

  1. 创建一个新的转销商对象并传递:
  2. var myreseller = New Reseller();
    myresller.Id = resellerId;
    //etc
    
    ResellerBL.UpdateReseller(myreseller);
    

    OR

    1. 修改(或添加重载)方法以获取四个参数:
    2. public static void UpdateReseller(int resellerId, string resellerName, string resellerMobile, string resellerRefNum)
      

答案 1 :(得分:0)

您的UpdateReseller方法只需一个参数:reseller

如果您希望能够将单个部件传递给方法,则需要修改签名或使用适当的参数创建重载。