C# 将布尔映射到LINQ到SQL数据源中的“Y”/“N”字段

C# 将布尔映射到LINQ到SQL数据源中的“Y”/“N”字段,c#,asp.net,linq,linq-to-sql,C#,Asp.net,Linq,Linq To Sql,我需要在数据库中的复选框和可以包含Y或N的char字段之间进行双向数据绑定 该复选框位于FormView中。无论何时提交表单,复选框的bool状态都会转换为数据源中相应的Y或N字段,然后提交到数据库。我正在使用LINQtoSQL设计器生成数据源代码。下面是我使用partials的想法 <asp:FormView ... datasource="DataSource1" EnableModelValidation="True" DefaultMode ="Edit"> <

我需要在数据库中的复选框和可以包含Y或N的char字段之间进行双向数据绑定

该复选框位于FormView中。无论何时提交表单,复选框的bool状态都会转换为数据源中相应的Y或N字段,然后提交到数据库。我正在使用LINQtoSQL设计器生成数据源代码。下面是我使用partials的想法

<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>
我相信这是正确的做法。当前,复选框确实反映了数据库字段的状态。但是,切换复选框并提交表单不会导致数据库中DbEnabled字段的更改

这是怎么做到的


编辑:唯一缺少的是在Linq to SQL设计器中将属性DbEnabled设置为Private。

您可以创建Private column属性并通过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);
 }

您可以创建私有列属性并通过公共属性公开它

这是一个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);
 }

谢谢你的回答。我重写了这个问题,希望能让它更清楚。复选框位于FormView中,数据源由Linq to SQL Designer Visual Studio生成。这就是为什么“局部”是个好主意。无论何时在VS中重新生成数据源,您的代码都不会被删除。我相信上面的部分代码与您的public bool BoolStatus属性相同。将生成数据源上下文。正如我所说,我上面的代码用于显示数据库字段的状态,但不用于更新它-不确定为什么您的代码不更新结果。在我所在的位置,我已经测试了LINQ-SQL-designer,并在使用/不使用数据源linqdataSource的情况下手动测试了它,它可以正常工作。注意:设置DBEnabled属性的private修饰符。是的,我还尝试改为设置private\u DBEnabled字段。我仍然没有更新数据库-不要更改生成的代码。从属性窗口打开DBML VS designer+选择DBEnabled属性+设置访问=私有。是的,这是缺少的部分。将访问权限设置为“私人”时,一切正常。谢谢你的回答。我重写了这个问题,希望能让它更清楚。复选框位于FormView中,数据源由Linq to SQL Designer Visual Studio生成。这就是为什么“局部”是个好主意。无论何时在VS中重新生成数据源,您的代码都不会被删除。我相信上面的部分代码与您的public bool BoolStatus属性相同。将生成数据源上下文。正如我所说,我上面的代码用于显示数据库字段的状态,但不用于更新它-不确定为什么您的代码不更新结果。在我所在的位置,我已经测试了LINQ-SQL-designer,并在使用/不使用数据源linqdataSource的情况下手动测试了它,它可以正常工作。注意:设置DBEnabled属性的private修饰符。是的,我还尝试改为设置private\u DBEnabled字段。我仍然没有更新数据库-不要更改生成的代码。从属性窗口打开DBML VS designer+选择DBEnabled属性+设置访问=私有。是的,这是缺少的部分。将访问权限设置为“私人”时,一切正常。ThanksNote:我还尝试获取和设置private _DbEnabled字段,而不是public DbEnabled字段。这没有什么区别,但我相信这是推荐的使用private字段的方法。注意:我还尝试获取和设置private _DbEnabled字段,而不是public DbEnabled字段。这没有什么区别,但我相信这是推荐的使用私有字段的方法。