喜 我使用.net framework 3.5的强类型数据集开发了一个应用程序。 有没有办法以编程方式更改tableadapter的源表? 日Thnx
答案 0 :(得分:0)
有几种方法可以做到这一点。首先,您可以添加一个从不同表中提取的新查询,然后执行该查询的方法,只要列匹配就可以。
如果你需要动态更改其中一个语句,你可以访问表适配器的命令集,它虽然受到保护,所以最简单的方法是创建一个局部类来扩展由设计师。完成此操作后,您可以添加自己的方法来返回数据。您可以使用 adapter.CommandCollection [0] .CommandText 来获取和设置创建的默认GetData命令的SQL。
执行此操作后,您可以更改它,清除参数,添加新参数或任何您想要执行的操作,然后使用更改的SQL设置CommandText,并调用 GetData 或任何您命名命令,它将像往常一样执行并返回。
这是一个代码示例:
using System.Data.SqlClient;
namespace DataTableAdapters
{
public partial class Data_ItemTableAdapter
{
public Data.Data_ItemDataTable GetDynamicExample(string SearchValue)
{
using (Data_ItemTableAdapter a = new Data_ItemTableAdapter())
{
SqlCommand cmd = a.CommandCollection[0];
cmd.Parameters.Clear();
string SQL = @"Select Data_Item_ID, Data from Data_Item where
SearchValue = @SearchValue";
cmd.CommandText = SQL;
cmd.Parameters.AddWithValue("@SearchValue", SearchValue);
return a.GetData();
}
}
}
}