[英]Is it possible to set a property via the setter of a property used to convert a value?
我們將 EFCore 與 Azure SQL 數據庫一起使用。 其中一列Yodels
是一個 tinyint,它只能映射到 C# 中的一個字節,但我們希望將它與 web 表單上的復選框一起使用,該表單需要一個布爾值。 為了顯示它,我們通過附加屬性YodelsBool
訪問它,該屬性將其轉換為布爾值。
public class Person
{
public string FirstName { get; set; }
public string LastName { get; set; }
public byte Yodels { get; set; }
public bool YodelsBool
{
get {
return Yodels > 0;
}
}
}
表單上的復選框: <input asp-for="Person.YodelsBool" class="form-control" type="checkbox" value="Person.YodelsBool" />
我們還希望能夠通過這個 YodelsBool 屬性設置值。 那可能嗎? 當我們添加一個 setter 時,它會失敗Invalid column name 'YodelsBool'
,因為它正在嘗試更新該特定屬性的數據庫。
我們嘗試了一個二傳手:
public bool YodelsBool
{
get {
return Yodels > 0;
}
set {
Yodels = Covert.ToByte(value);
}
}
我們如何在不更改數據庫的情況下完成這項工作? 我們正在使用 tinyint 以防我們希望在未來某個時候擴展到 true/false 之外。
將[NotMapped]
添加到屬性:
[NotMapped]
public bool YodelsBool
{
get {
return Yodels > 0;
}
set {
Yodels = Covert.ToByte(value);
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.