1

У меня возникли проблемы с созданием простого отношения «один к одному» с использованием ядра Entity Framework. Сущности и переопределение метода OnModelCreating выглядеть следующим образом:Entify Framework Core one to one отношения

public class Blog 
{ 
    public int BlogId { get; set; } 
    public string Url { get; set; } 

    public BlogImage BlogImage { get; set; } 
} 

public class BlogImage 
{ 
    public int BlogImageId { get; set; } 
    public byte[] Image { get; set; } 
    public string Caption { get; set; } 

    public int BlogForeignKey { get; set; } 
    public Blog Blog { get; set; } 
} 

    protected override void OnModelCreating(ModelBuilder modelBuilder) 
    { 
     modelBuilder.Entity<Blog>() 
      .HasOne(p => p.BlogImage) 
      .WithOne(i => i.Blog) 
      .HasForeignKey<BlogImage>(b => b.BlogForeignKey); 
    } 

Когда я передать команду Update-Database я получаю сообщение об ошибке:

Consider using the 'await' operator to await non-blocking API calls, or 'await Task.Run(...)' to do CPU-bound work on a background thread. 
System.Data.SqlClient.SqlException: Incorrect syntax near the keyword 'WHERE'. 
    at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction) 
    at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj, Boolean callerHasConnectionLock, Boolean asyncClose) 
    at System.Data.SqlClient.TdsParser.TryRun(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj, Boolean& dataReady) 
    at System.Data.SqlClient.SqlCommand.RunExecuteNonQueryTds(String methodName, Boolean async, Int32 timeout, Boolean asyncWrite) 
    at System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource`1 completion, Boolean sendToPipe, Int32 timeout, Boolean asyncWrite, String methodName) 
    at System.Data.SqlClient.SqlCommand.ExecuteNonQuery() 
    at Microsoft.EntityFrameworkCore.Storage.Internal.RelationalCommand.Execute(IRelationalConnection connection, String executeMethod, IReadOnlyDictionary`2 parameterValues, Boolean openConnection, Boolean closeConnection) 
    at Microsoft.EntityFrameworkCore.Storage.Internal.RelationalCommand.ExecuteNonQuery(IRelationalConnection connection, IReadOnlyDictionary`2 parameterValues, Boolean manageConnection) 
    at Microsoft.EntityFrameworkCore.Migrations.Internal.MigrationCommandExecutor.ExecuteNonQuery(IEnumerable`1 migrationCommands, IRelationalConnection connection) 
    at Microsoft.EntityFrameworkCore.Migrations.Internal.Migrator.Migrate(String targetMigration) 
    at Microsoft.EntityFrameworkCore.Design.MigrationsOperations.UpdateDatabase(String targetMigration, String contextType) 
    at Microsoft.EntityFrameworkCore.Tools.Cli.DatabaseUpdateCommand.<>c__DisplayClass0_0.<Configure>b__0() 
    at Microsoft.Extensions.CommandLineUtils.CommandLineApplication.Execute(String[] args) 
    at Microsoft.EntityFrameworkCore.Tools.Cli.Program.Main(String[] args) 
ClientConnectionId:f21894a0-4ae6-4b73-95fc-40a7804cf9cb 
Error Number:156,State:1,Class:15 
Incorrect syntax near the keyword 'WHERE'. 

Что я должен проверить? Спасибо!

+0

Модель в порядке. Не могу воспроизвести. –

+0

Спасибо, Иван Стоев за попытку воспроизвести его. –

ответ

1

думаю. Обычно потому, что в отношениях один к одному структура сущности не может вызывать внешние ключи и главные ключи.

Вы должны выразить их явно, чтобы обеспечить правильное создание внешнего ключа.

modelBuilder.Entity<Blog>() 
       .HasOne(parent => parent.BlogImage).WithOne(child => child.Blog) 
       .HasPrincipalKey<Blog>(parent => parent.BlogId).HasForeignKey<BlogImage>(child => child.BlogForeignKey); 
1

Благодарим за попытку помочь. Кажется, что проблема была связана с версией SQL Server. Я не знал, что EFCore несовместим с SQL Server 2005.

Спасибо! С уважением!

Смежные вопросы