我需要在db中包含Y或N的复选框和char字段之间进行双向数据绑定。
该复选框位于FormView中。无论何时提交表单,复选框的bool状态都会转换为数据源中相应的Y或N字段,然后提交到数据库。我使用LINQ to SQL Designer生成数据源代码。这是我在使用偏见时的想法。
<asp:FormView ... datasource="DataSource1" EnableModelValidation="True" DefaultMode ="Edit">
<EditItemTemplate>
...
<asp:checkbox ... checked='<%# Bind("Enabled") %>'>
...
</EditItemTemplate>
</asp:FormView>
<asp:LinqDataSource ID="DataSource1" runat="server"
ContextTypeName="WebPages.WebPagesDataContext" EnableDelete="True"
EnableInsert="True" EnableUpdate="True" TableName="Car">
</asp:LinqDataSource>
然后我可以使用partial将我自己的Enabled
属性添加到生成的数据源。部分类位于App_Code中,与linq数据源位于相同的命名空间中。
partial class Car
{
public bool Enabled
{
get { return DbEnabled == 'Y' }
set { DbEnabled = value ? 'Y' : 'N' }
}
}
我相信这是正确的做法。目前,该复选框确实反映了数据库字段的状态。但是,切换复选框并提交表单不会导致数据库中DbEnabled字段的更改。
这是怎么做到的?
编辑:使这项工作失败的唯一方法是在Linq to SQL设计器中将属性DbEnabled设置为Private。
答案 0 :(得分:4)
您可以创建私有列属性并通过公共属性公开它。
这是一个Emp实体,
[Table(Name="Emp")]
public class Emp
{
[Column(Name = "No", IsPrimaryKey = true)]
public int Id { get; set; }
[Column(Name="Name")]
public string Name { get; set; }
[Column(Name = "Status")]
private char Status { get; set; }
public bool BoolStatus
{
get { return Status == 'Y' ? true : false; }
set
{
if (value)
Status = 'Y';
else
Status = 'N';
}
}
public override string ToString()
{
return string.Format("{0} {1} {2}", Id, Name, BoolStatus);
}
}
创建上下文,
string cnstr = @"connection_string";
DataContext dx = new DataContext(cnstr);
Table<Emp> emps=dx.GetTable<Emp>();
Emp a = new Emp() { Id=101, Name="Foo", BoolStatus=true };
emps.InsertOnSubmit(a);
dx.SubmitChanges();
foreach(Emp emp in emps)
{
Console.WriteLine(emp);
}