如何在C#中将GridView连接到两个不同的sqldatasource

本文关键字:两个 sqldatasource 中将 GridView 连接 | 更新日期: 2023-09-27 18:21:55

我想知道如何将单个GridView连接到两个SqlDataSource对象?

目前,我遇到一个错误,指出DataSource和DataSourceID都是在"GridView1"上定义的,所以我删除了一个定义。但我不想删除任何定义,因为两者都很重要。

Aspx标记

SqlDataSource1

<asp:SqlDataSource ID="SqlDataSource1" runat="server" 
                ConnectionString="<%$ ConnectionStrings:DBCS %>" 
                DeleteCommand="DELETE FROM [vendor_master] WHERE [vendorID] = @vendorID" 
                InsertCommand="INSERT INTO [vendor_master] ([Vname], [Email], [Mobile], [Landline], [Address], [Pincode]) VALUES (@Vname, @Email, @Mobile, @Landline, @Address, @Pincode)" 
                SelectCommand="SELECT * FROM [vendor_master]" 
                UpdateCommand="UPDATE [vendor_master] SET [Vname] = @Vname, [Email] = @Email, [Mobile] = @Mobile, [Landline] = @Landline, [Address] = @Address, [Pincode] = @Pincode WHERE [vendorID] = @vendorID">
                <DeleteParameters>
                    <asp:Parameter Name="vendorID" Type="Int32" />
                </DeleteParameters>
                <InsertParameters>
                    <asp:Parameter Name="Vname" Type="String" />
                    <asp:Parameter Name="Email" Type="String" />
                    <asp:Parameter Name="Mobile" Type="Int64" />
                    <asp:Parameter Name="Landline" Type="Int64" />
                    <asp:Parameter Name="Address" Type="String" />
                    <asp:Parameter Name="Pincode" Type="Int32" />
                </InsertParameters>
                <UpdateParameters>
                    <asp:Parameter Name="Vname" Type="String" />
                    <asp:Parameter Name="Email" Type="String" />
                    <asp:Parameter Name="Mobile" Type="Int64" />
                    <asp:Parameter Name="Landline" Type="Int64" />
                    <asp:Parameter Name="Address" Type="String" />
                    <asp:Parameter Name="Pincode" Type="Int32" />
                    <asp:Parameter Name="vendorID" Type="Int32" />
                </UpdateParameters>
            </asp:SqlDataSource>

SqlDataSource2

<asp:SqlDataSource ID="SqlDataSource2" runat="server" 
                ConnectionString="<%$ ConnectionStrings:DBCS %>" SelectCommand="FindVendor" 
                SelectCommandType="StoredProcedure">
                <SelectParameters>
                    <asp:ControlParameter ControlID="txtFindVendor" Name="name" PropertyName="Text" 
                        Type="String" />
                </SelectParameters>
            </asp:SqlDataSource>

C#代码

protected void btnAddVendor_Click(object sender, EventArgs e)
{
    if (IsValid)
    {
        SqlDataSource1.InsertParameters["Vname"].DefaultValue = txtName.Text;
        SqlDataSource1.InsertParameters["Email"].DefaultValue = txtEmail.Text;
        SqlDataSource1.InsertParameters["Mobile"].DefaultValue = txtMobile.Text;
        SqlDataSource1.InsertParameters["Landline"].DefaultValue = txtLandline.Text;
        SqlDataSource1.InsertParameters["Address"].DefaultValue = txtAddress.Text;
        SqlDataSource1.InsertParameters["Pincode"].DefaultValue = txtPincode.Text;
        SqlDataSource1.Insert();
    }
}
protected void btnFindName_Click(object sender, EventArgs e)
{
    GridView1.DataSource = SqlDataSource2;
    GridView1.DataBind();
}

如何在C#中将GridView连接到两个不同的sqldatasource

简化每次点击事件,而不是GridView1.DataSource = SqlDataSource2更改。。。

protected void btnFindName_Click(object sender, EventArgs e)
    {
        GridView1.DataSourceID = "SqlDataSource2";
        GridView1.DataBind();
    }

您必须在一个SQLDatasource中加入两个表。如下所示:

SELECT Orders.OrderID, Customers.CustomerName, Orders.OrderDate
  FROM Orders
  INNER JOIN Customers
  ON Orders.CustomerID=Customers.CustomerID; 

错误为Both DataSource and DataSourceID已清除。问题出在Gridview的html中。

删除属性之一DataSourceDataSourceID

SO 上的类似问题

  1. DataSource和DataSourceID都是在';GridView1';。删除一个定义

编辑1

或者,您可以尝试从设计端使用sqldatasource将数据绑定到数据网格,也可以从代码背后使用c#代码。。

<asp:gridview  runat="server" autogeneratecolumns="False" 
     DataSourceID="Datasource1">

这里指定了DataSourceID,并且在GridView1.DataSource = SqlDataSource2;后面的代码中导致了问题。