将bool映射到LINQ to SQL数据源中的“Y”/“N”字段

时间:2012-02-24 07:03:04

标签: c# asp.net linq linq-to-sql

我需要在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。

1 个答案:

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