代码首先在西里尔语中播种数据

meg*_*00b 5 .net c# entity-framework code-first

我正在使用种子方法来填充数据库.一些对象具有西里尔字母的属性.例:

context.Wines.AddOrUpdate(new Wine()
       {
           Id = 1,
           Name = "???????",
           etc........................................
Run Code Online (Sandbox Code Playgroud)

这些对象在数据库中正确创建,但是当我在MS SQL管理工作室中检查数据库而不是葡萄酒的名称为"Шардоне"时,它显示为"Øàðäîíå".

奇怪的是,当我在我的Startup类中创建葡萄酒时,如下所示:

var db = new WineSystemDbContext();
var ShardoneWine = new Wine { Name = "???????};
db.Wines.Add(ShardoneWine);
Run Code Online (Sandbox Code Playgroud)

一切都在数据库中以西里尔文显示.

你知道可能导致这种情况的原因吗?

Vad*_*nov 5

您可以在连接字符串中指定connectin的字符集.只需将此部分添加到您的连接:

charset=UTF8;
Run Code Online (Sandbox Code Playgroud)

如果没有结果,您可以尝试更改Configuration.cs文件的char-set.有两种方法可以做到这一点.

  1. 在Visual Studio编辑器中关闭Configuration.cs,然后在解决方案资源管理器中右键单击该文件并选择"打开方式..." - >"带编码的CSharp编辑器",并从列表中选择"Unicode(带签名的UTF-8) - 代码页65001"选项(如果这个代码页会显示一些'中文'符号,请尝试其他代码页).现在修复您的cyrilic章节并保存Configuration.cs文件.
  2. 选择"文件" - >"高级保存选项",然后使用以UTF-8编码方式播种数据的方法保存文件.

如果使用ntext列类型,也可能会出现问题.