以编程方式更改.net强类型数据集中的表名称

时间:2010-10-29 10:13:22

标签: asp.net strongly-typed-dataset

喜 我使用.net framework 3.5的强类型数据集开发了一个应用程序。 有没有办法以编程方式更改tableadapter的源表?  日Thnx

1 个答案:

答案 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();

            }

        }
    }
}