我有一个舞蹈学院的网站,用户可以注册和添加/放弃舞蹈课程。
在要删除特定舞蹈的网页中,对于特定用户,下拉列表会显示她已注册的舞蹈。
现在我要从列表中删除其中一个舞蹈。
所以我将删除表中的行以及下拉列表中的行。问题是,每当具有最低ID(索引)的项目被删除时,无论用户选择哪一项。
我认为我正在为下拉列表错误地存储DataTextField和DataValueField。有人可以帮帮我吗? 代码是:
private void PopulateDanceDropDown()
{
var registereddanceList = from dd in context.DANCER_AND_DANCE
where dd.UserId == dancerId
select new
{
Text = dd.DanceName,
Value = dd.DanceId
};
dances.DataSource = registereddanceList;
dances.DataTextField = "Text";
dances.DataValueField = "Value";
dances.DataBind();
}
protected void dropthedance(object o, EventArgs e)
{
String strDataValueField = dances.SelectedItem.Value;
int danceIDFromDropDown = Convert.ToInt32(strDataValueField);
var dancer_dance = from dd in context.DANCER_AND_DANCE
where dd.DanceId == danceIDFromDropDown
select dd;
foreach (var dndd in dancer_dance)
{
context.DANCER_AND_DANCE.DeleteOnSubmit(dndd);
}
try
{
context.SubmitChanges();
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
PopulateDanceDropDown();
}
<asp:DropDownList ID = "dances" runat="server">
</asp:DropDownList>
<asp:Button ID="dropDance" runat="server" OnClick="dropthedance" Text="Drop Class" BackColor="Maroon" ForeColor="#FFCC99"/>
答案 0 :(得分:0)
正如您的问题所说,您希望在不将其存储在Linq中的情况下访问记录。
所以低于一个可能是你的另一种选择。
首先将数据库中的所有数据存储到,让我们说List<NameIDPair>
继承NameIDPair
可能是什么:
class NameIDPair
{
public NameIDPair(){}
public string NameValue{get;set;}
public string IDValue{get;set;}
}
然后按如下方式填充下拉列表:
List<NameIDPair> storeInMe = From Database
foreach(NameIDPair pair in storeInMe )
{
ListItem item = new ListItem();
item.Value = pair.IDValue;
item.Text = pair.NameValue;
ddldancesList.Items.Add(item);
}
然后为了删除TheDance,你可以调用删除存储过程删除相同的...
希望这会有所帮助......