如何在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();
}
简化每次点击事件,而不是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中。
删除属性之一DataSource
或DataSourceID
。
SO 上的类似问题
- DataSource和DataSourceID都是在';GridView1';。删除一个定义
编辑1
或者,您可以尝试从设计端使用sqldatasource
将数据绑定到数据网格,也可以从代码背后使用c#代码。。
<asp:gridview runat="server" autogeneratecolumns="False"
DataSourceID="Datasource1">
这里指定了DataSourceID
,并且在GridView1.DataSource = SqlDataSource2;
后面的代码中导致了问题。