C# 将布尔映射到LINQ到SQL数据源中的“Y”/“N”字段
我需要在数据库中的复选框和可以包含Y或N的char字段之间进行双向数据绑定 该复选框位于FormView中。无论何时提交表单,复选框的bool状态都会转换为数据源中相应的Y或N字段,然后提交到数据库。我正在使用LINQtoSQL设计器生成数据源代码。下面是我使用partials的想法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"> <
<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字段。这没有什么区别,但我相信这是推荐的使用私有字段的方法。