繁体   English   中英

在ASP.NET的C#中更新DropDownList的DataSource

[英]Updating the DataSource of a DropDownList in ASP.NET's C#

我有一个使用DropDownList的编辑表单,使用DataSource连接到SQL服务器表。 此编辑表单允许用户将表的“IsDeleted”列值设置为1,然后将其隐藏在所有应用程序的查询中。 (所以事务仍然存在于数据库中,但不存在于应用程序中)

我遇到的问题是,如果编辑表单所在的页面未完全保留,然后再次输入,则该条目仍保留在DataSource中。

基本上,DataSource没有更新。 (它不会运行其select语句并重新填充,直到重新加载整个页面)。 我试图使用页面刷新,它似乎不起作用,只是完全转到另一个页面然后回来似乎更新数据源。

如何以编程方式刷新DataSource的内容而无需重新创建整个DataSource本身?

您可能希望下次添加一些代码。 我现在最好的猜测是你没有做任何OnPostback。

所以我最终采取了我不想做的事情,希望有一种“最佳实践”的方式来实现它(希望已经内置到DataSources中),但似乎不是。

所需要的只是再次将DataSource的参数重新分配给它,然后将DataSource分配回DropDownList,就像我创建一个新的一样。

我创建了以下方法,然后在删除按钮的事件结束时调用该方法。

protected void DropDownList_Reload()
    {
        MyDataSource.ConnectionString = ConfigurationManager.ConnectionStrings["MyDatabase"].ConnectionString;
        MyDataSource.SelectCommand = "SELECT * FROM [tblMyTable] WHERE [IsDeleted] <> 1";

        cbxDropDownList.DataSourceID = "MyDataSource";
        cbxDropDownList.DataTextField = "MyHeader";
        cbxDropDownList.DataValueField = "MyHeader";
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM