c# - 将 bool 映射到 LINQ to SQL 数据源中的 'Y'/'N' 字段

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

我需要在复选框和数据库中可以包含 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/

相关文章:

c# - 异步等待导致死锁

javascript - 阻止先前的点击请求

C# 使用 linq 将列转换为行?

c# - 如何从 Action() 返回值?

c# - 在输入文本中有多个 % 运算符的 LINQ 中等效的 SQL LIKE 运算符是什么?

c# - 使用 Linq 在 BindingList<T> 中搜索

c# - 是否可以通过 odata 查询 soap 端点?

c# - TextBlock 中的绑定(bind)在 WPF 中不起作用

asp.net - @Html.CheckBoxFor 不会更改变量的值

ASP.NET Core 2.0 Razor 与 Angular/React/等