Эта статья является зеркальной статьёй машинного перевода, пожалуйста, нажмите здесь, чтобы перейти к оригиналу.

Вид: 23619|Ответ: 0

[Источник] Тип строки первого атрибута EF-кода добавляет свойства индекса

[Скопировать ссылку]
Опубликовано 23.11.2017 18:47:15 | | | |
Если вы хотите создать индекс и ускорить запрос, добавьте атрибут [Index] к атрибуту и автоматически сгенерируйте код следующим образом:

Мы обновляем базу данных, и ошибка такова:



System.Data.SqlClient.SqlException (0x80131904): table 'dbo. Столбец «Телефон» в «Аккаунт» не может использоваться как ключевой столбец в индексе.
   at System.Data.SqlClient.SqlConnection.OnError (SqlException exception, Boolean breakConnection, Action'1 wrapCloseInAction)
   at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection, Action'1 wrapCloseInAction)
   at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj, Boolean callerHasConnectionLock, Boolean asyncClose)
   В 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, булев async, Int32 timeout, булев asyncWrite)
   В System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource'1 completion, String methodName, булевый sendToPipe, тайм-аут Int32, Boolean&usedCache, булев asyncWrite, булев в Retry)
   В System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
   В System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher. <NonQuery>b__0(DbCommand t, DbCommandInterceptionContext'1 c)
   В System.Data.Entity.Infrastructure.Interception.InternalDispatcher'1.Dispatch[TTarget,TInterceptionContext,TResult](TTarget target, Func'3 operation, TInterceptionContext interceptionContext, Action'3 выполняется, Action'3 выполнено)
   В System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher.NonQuery(DbCommand command, DbCommandInterceptionContext interceptionContext)
   В System.Data.Entity.Internal.InterceptableDbCommand.ExecuteNonQuery()
   В System.Data.Entity.Migrations.DbMigrator.ExecuteSql(MigrationStatement migrationStatement, DbConnection connection, dbTransaction transaction, DbInterceptionContext ПерехватКонтекст)
   В System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ExecuteSql(MigrationStatement migrationStatement, DbConnection connection, dbTransaction transaction , DbПерехватКонтекст, перехватКонтекст)
   В System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, DbConnection connection, dbTransaction transaction, dbПерехватКонтекст перехватаКонтекст)
   В System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinTransaction(IEnumerable'1 migrationStatements, DbTransaction transaction, dbInterceptionContext ПерехватКонтекст)
   In System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinNewTransaction(IEnumerable'1 migrationStatements, DbConnection connection, DbInterceptionContext ПерехватКонтекст)
   В System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, DbConnection connection, DbInterceptionContext interceptionContext)
   at System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, соединение DbConnection)
   на сайте System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClass32. <ExecuteStatements>b__30()
   В System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.<>c__DisplayClass1. <Execute>b__0()
   at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute[TResult](операция Func'1)
   В System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute(операция действия)
   В System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable'1 migrationStatements, DbTransaction existingTransaction)
   In System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable'1 migrationStatements)
   at System.Data.Entity.Migrations.Infrastructure.MigratorBase.ExecuteStatements(IEnumerable'1 migrationStatements)
   В System.Data.Entity.Migrations.DbMigrator.ExecuteOperations(String migrationId, VersionedModel targetModel, IEnumerable'1 operations, IEnumerable'1 systemOperations, булев понижение, булева автосистема)
   на System.Data.Entity.Migrations.DbMigrator.ApplyMigration(DbMigration, DbMigration lastMigration)
   на System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ApplyMigration(DbMigration, DbMigration lastMigration)
   at System.Data.Entity.Migrations.DbMigrator.Upgrade(IEnumerable'1 pendingMigrations, String targetMigrationId, String lastMigrationId)
   at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.Upgrade(IEnumerable'1 pendingMigrations, String targetMigrationId, String lastMigrationId)
   на System.Data.Entity.Migrations.DbMigrator.UpdateInternal(String targetMigration)
   В System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClasse. <Update>b__d()
   at System.Data.Entity.Migrations.DbMigrator.EnsureDatabaseExists(Action mustSucceedToKeepDatabase)
   at System.Data.Entity.Migrations.Infrastructure.MigratorBase.EnsureDatabaseExists(Action mustSucceedToKeepDatabase)
   на System.Data.Entity.Migrations.DbMigrator.Update (String targetMigration)
   В System.Data.Entity.Migrations.Infrastructure.MigratorBase.Update (String targetMigration)
   на System.Data.Entity.Migrations.Design.ToolingFacade.UpdateRunner.RunCore()
   В System.Data.Entity.Migrations.Design.ToolingFacade.BaseRunner.Run()
ClientConnectionId:2b5f614b-caab-4be6-bc1b-a813b7356739
Номер ошибки: 1919, штат: 1, класс: 16
Table 'dbo. Столбец «Телефон» в «Аккаунт» не может использоваться как ключевой столбец в индексе.


Причина ошибки в том, что все свойства строк ef по умолчанию относятся к типу NVARCHAR(Max),

Решение следующее:

Выполните длину струны





Как показано на фотографии, создание удалось!





Предыдущий:Как хранить строки длиннее 4000 символов в NHibernate 3.3
Следующий:C# Scramble массивы
Отказ:
Всё программное обеспечение, программные материалы или статьи, публикуемые Code Farmer Network, предназначены исключительно для учебных и исследовательских целей; Вышеуказанный контент не должен использоваться в коммерческих или незаконных целях, иначе пользователи несут все последствия. Информация на этом сайте взята из Интернета, и споры по авторским правам не имеют отношения к этому сайту. Вы должны полностью удалить вышеуказанный контент с компьютера в течение 24 часов после загрузки. Если вам нравится программа, пожалуйста, поддержите подлинное программное обеспечение, купите регистрацию и получите лучшие подлинные услуги. Если есть нарушение, пожалуйста, свяжитесь с нами по электронной почте.

Mail To:help@itsvse.com