我需要在复选框和数据库中可以包含 Y 或 N 的字符字段之间进行双向数据绑定(bind)。
复选框位于 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>
然后我可以使用部分代码将我自己的 Enabled
属性添加到生成的数据源。部分类位于 App_Code 中,并且与 linq 数据源位于相同的命名空间中。
partial class Car
{
public bool Enabled
{
get { return DbEnabled == 'Y' }
set { DbEnabled = value ? 'Y' : 'N' }
}
}
我相信这是正确的做法。目前,该复选框确实反射(reflect)了数据库字段的状态。但是,切换复选框并提交表单不会导致数据库中的 DbEnabled 字段发生变化。
这是怎么做到的?
编辑:使这项工作唯一缺少的是在 Linq to SQL 设计器中将属性 DbEnabled 设置为 Private。
最佳答案
您可以创建私有(private)列属性并通过公共(public)属性公开它。
这是一个 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);
}
关于c# - 将 bool 映射到 LINQ to SQL 数据源中的 'Y'/'N' 字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9426731/