- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
奇怪的问题,可能没有答案......我继承了一个旧的 mysql 数据库,不幸的是,许多“ bool ”字段被设置为 VARCHAR 而不是更合适的 TINYINT(1)......
我现在在数据库之上运行 Entity Framework Core。因为我不知道 bool 值在哪里都被使用,所以我还不能完全更新数据库,但我希望能够在 EF 中实际使用字符串值作为 bool 值... 有没有更改模型类型的方法,以便模型将所有内容整齐地包装为 bool 值,但当我将其推送到数据库时它仍然将字段视为字符串?
基本上,在我的代码中,我希望能够做到这一点: object.IsGood = true;
取而代之的是:object.IsGood = "TRUE"
我的模型会谨慎地处理值转换,就像这样写入数据库(我需要另一个转换器来从数据库中读回 bool 值):
string databaseValue = "";
if (object.IsGood)
{
databaseValue = "TRUE";
}
else
{
databaseValue = "FALSE";
}
我能想到的任何方式,当我改变模型时,我实际上是在改变数据库……我知道我可以将模型本身包装到另一个类中,但这似乎令人困惑。我很想只更新数据库,但要弄清楚代码触及这些值的所有可能位置可能会非常痛苦……所以我希望有一个中间解决方案。
最佳答案
我总是在术语“映射”或“包装器”下搜索此类内容,但这些内容并没有从文档中提出任何似乎有用的东西……克里斯托弗的评论让我走上了正确的轨道,我得到了我想要的正在寻找。
显然“值(value)转化”是我一直在寻找的: Value Conversions EF Core
编辑:我删除了文档示例,因为任何人都可以查找它。我在下面添加我的真实示例。
因为我想在字符串和 bool 值之间来回转换,所以我将这个转换器创建为静态值,这样我就可以在几个模型中重用它:
public static class EntityFrameworkCoreValueConverters
{
/// <summary>
/// converts values stored in the database as VARCHAR to a nullable bool
/// handles "TRUE", "FALSE", or DBNULL
/// </summary>
public static ValueConverter<bool?, string> dbVarCharNullableToBoolNullableConverter = new ValueConverter<bool?, string>(
v => v == true ? "TRUE" : v == false ? "FALSE" : null,
v => v.ToUpper() == "TRUE" ? true : false
);
}
请注意,作为 Microsoft.EntityFrameworkCore.Storage.ValueConversion
命名空间的一部分,已经存在一个 BoolToStringConverter
,但这似乎无法处理空值,我需要。
然后我可以将模型值更改为 bool?
而不是 string
,但不考虑实际的数据库值类型。
dbVarCharNullableToBoolNullableConverter
然后可以应用于我的 OnModelCreating
方法(或者在我的例子中 Configure
应用于模型本身,它在 OnModelCreating
方法:
public void Configure(EntityTypeBuilder<MachineHelpRequests> builder)
{
//... model builder code above
builder.Property(e => e.IsAcknowledged)
.HasColumnName("acknowledged_mhr")
.HasColumnType("varchar(45)")
.HasConversion(EntityFrameworkCoreValueConverters.dbVarCharNullableToBoolNullableConverter);
//... model builder code below
}
关于c# - 如何在我的模型上使用 bool 值来包装数据库中的字符串值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57316903/
如何使用 SPListCollection.Add(String, String, String, String, Int32, String, SPListTemplate.QuickLaunchO
我刚刚开始使用 C++ 并且对 C# 有一些经验,所以我有一些一般的编程经验。然而,似乎我马上就被击落了。我试过在谷歌上寻找,以免浪费任何人的时间,但没有结果。 int main(int argc,
这个问题已经有答案了: In Java 8 how do I transform a Map to another Map using a lambda? (8 个回答) Convert a Map>
我正在使用 node + typescript 和集成的 swagger 进行 API 调用。我 Swagger 提出以下要求 http://localhost:3033/employees/sear
我是 C++ 容器模板的新手。我收集了一些记录。每条记录都有一个唯一的名称,以及一个字段/值对列表。将按名称访问记录。字段/值对的顺序很重要。因此我设计如下: typedef string
我需要这两种方法,但j2me没有,我找到了一个replaceall();但这是 replaceall(string,string,string); 第二个方法是SringBuffer但在j2me中它没
If string is an alias of String in the .net framework为什么会发生这种情况,我应该如何解释它: type JustAString = string
我有两个列表(或字符串):一个大,另一个小。 我想检查较大的(A)是否包含小的(B)。 我的期望如下: 案例 1. B 是 A 的子集 A = [1,2,3] B = [1,2] contains(A
我有一个似乎无法解决的小问题。 这里...我有一个像这样创建的输入... var input = $(''); 如果我这样做......一切都很好 $(this).append(input); 如果我
我有以下代码片段 string[] lines = objects.Split(new string[] { "\r\n", "\n" }, StringSplitOptions.No
这可能真的很简单,但我已经坚持了一段时间了。 我正在尝试输出一个字符串,然后输出一个带有两位小数的 double ,后跟另一个字符串,这是我的代码。 System.out.printf("成本:%.2
以下是 Cloud Firestore 列表查询中的示例之一 citiesRef.where("state", ">=", "CA").where("state", "= 字符串,我们在Stack O
我正在尝试检查一个字符串是否包含在另一个字符串中。后面的代码非常简单。我怎样才能在 jquery 中做到这一点? function deleteRow(locName, locID) { if
这个问题在这里已经有了答案: How to implement big int in C++ (14 个答案) 关闭 9 年前。 我有 2 个字符串,都只包含数字。这些数字大于 uint64_t 的
我有一个带有自定义转换器的 Dozer 映射: com.xyz.Customer com.xyz.CustomerDAO customerName
这个问题在这里已经有了答案: How do I compare strings in Java? (23 个回答) 关闭 6 年前。 我想了解字符串池的工作原理以及一个字符串等于另一个字符串的规则是
我已阅读 this问题和其他一些问题。但它们与我的问题有些无关 对于 UILabel 如果你不指定 ? 或 ! 你会得到这样的错误: @IBOutlet property has non-option
这两种方法中哪一种在理论上更快,为什么? (指向字符串的指针必须是常量。) destination[count] 和 *destination++ 之间的确切区别是什么? destination[co
This question already has answers here: Closed 11 years ago. Possible Duplicates: Is String.Format a
我有一个Stream一个文件的,现在我想将相同的单词组合成 Map这很重要,这个词在 Stream 中出现的频率. 我知道我必须使用 collect(Collectors.groupingBy(..)
我是一名优秀的程序员,十分优秀!