0

まず、読んでいただきありがとうございます。私はEFを使用してデータベースを更新しようとするといくつかの困難を抱えています。他のプロジェクトでこれと同じアプローチを使用していたので、おそらくデータベースに問題があると思っていますが、私はそれを見ていません。データベースは、SQL 2005でレガシーデシベルで、命名規則が望まれるためにたくさん持っている、それゆえ私はHasColumnNameメソッドを介して、より一貫性のあるものに一貫性のない名前をマッピングしてきた:。のようにReferentialConstraintの従属プロパティは、ストア生成の列にマップされます。列:

 modelBuilder.Entity<Case_Person_1>().ToTable("dbo.Case_Person_1"); 
     modelBuilder.Entity<Case_Person_1>().Property(c => c.Id).HasColumnName("CaseNumber"); 

私は私の問題を他の同様のものと比較して、外来キーの関係が正しい方向に向いていることを確認するために調査し、IDはPK上にのみ存在することを確認しました。データ生成オプションが明示的に設定されていない場合、データベースに対してコマンドが実行されますが、b/cに失敗します。キーが0で、オプションが明示的にOFFに設定されています。私はSQLプロファイラでこれを見ることができます。アイデンティティのオプションを追加すると、参照制約エラーが発生します。

私はこれを2日間失ってしまっています。解決には至らず、私は自分のロープの最後にいます。 私の他のプロジェクトでは、POCOをDatabaseGeneratedOptionで飾る必要はありませんでしたが、挿入時にエラーは発生しませんでした。 System.Data.Entity.Infrastructure:完全なエラーの詳細はこちら


これは、SQL 2005のものだった場合、私は知りませんでした、または私は何かを欠けている場合...。 DbUpdateExceptionがキャッチされました
メッセージ=エントリの更新中にエラーが発生しました。詳細については、 例外を参照してください。ソース= EntityFrameworkのStackTrace:System.Data.Entity.DbContext.SaveChangesでSystem.Data.Entity.Internal.LazyInternalContext.SaveChangesでSystem.Data.Entity.Internal.InternalContext.SaveChanges() で () () で C:¥TFS¥CGProjects¥GOC¥SCYFIS¥PHTSY¥Dev¥src¥Datalayer¥Helpers¥EntityExtensions.cs内のScyfis.Ocyf.DataLayer.EntityExtensions.AddItem [T](Tエンティティ、DbSet 1 dbSet, DbContext context, Action 2 foriegnKeyUpdater): C:¥TFS¥CGProjects¥GOC¥SCYFIS¥PHTSY¥Dev¥src¥Datalayer¥Helpers¥EntityExtensions.cs内のScyfis.Ocyf.DataLayer.EntityExtensions.SaveItem [T](Tエンティティ、DbSet 1 dbSet, DbContext context, Action 2 foriegnKeyUpdater)で、 を編集します。 :line at Scyfis.Ocyf.DataLayer.Cas e_PHTSYRepository.Save Cで(Case_PHTSYモデル):\ TFS \ CGProjects \ GOC \ SCYFIS \ PHTSY \ Devの\ SRC \ Datalayer \カスタム\ Case_PHTSYRepository.cs:Scyfis.Ocyf.Service.Case_PHTSYService.Createでライン(Case_PHTSYモデル: C:¥TFS¥CGProjects¥GOC¥SCYFIS¥PHTSY¥Dev¥src¥Service¥Custom¥Case_PHTSYService.cs:行 184 InnerException:System.Data.UpdateException メッセージ=エントリの更新中にエラーが発生しました。詳細については、内部例外を参照してください。 ソース= System.Data.Entity のStackTrace:System.Data.Mapping.Update.Internal.TableChangeProcessor.CompileCommands(ChangeNode changeNode、UpdateCompilerコンパイラ) で System.Data.Mapping.Update.Internal.UpdateTranslator.d_で0.MoveNext() System.Data.Mapping.Update.Internal.UpdateTranslator.ProduceCommandsでSystem.Linq.Enumerable.d _71 コマンド、UpdateTranslatorトランスレータ) (AT) System.Data.Mapping.Updateで.Internal.UpdateTranslator。System.Data.EntityClient.EntityAdapter.Updateで更新(IEntityStateManager のStateManager、IEntityAdapterアダプタ) (IEntityStateManager entityCache)System.Data.Objects.ObjectContext.SaveChanges(SaveOptionsオプション)で System.Data.Entity.Internalで 。 InternalContext.SaveChanges() InnerException:System.InvalidOperationException メッセージ= ReferentialConstraintの依存プロパティがストア生成の列にマップされています。列: 'Id'。 ソース= System.Data.Entity のStackTrace:System.Data.Mapping.Update.Internal.UpdateCompiler.BuildSetClausesで ( ターゲット、PropagatorResult行、PropagatorResult originalRow、 TableChangeProcessorプロセッサ、ブールinsertMode、Dictionary`2 & outputIdentifiersをDbExpressionBinding 、DbExpression &はSystem.Data.Mapping.Update.Internal.TableChangeProcessor.CompileCommandsでSystem.Data.Mapping.Update.Internal.UpdateCompiler.BuildInsertCommand(PropagatorResult newRow、TableChangeProcessorプロセッサ) で)、ブール& rowMustBeTouchedを返す(ChangeNode changeNode、UpdateCompil ERコンパイラ) のInnerException:

public partial class Case_PHTSY 
{ 
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)] 
    public int Id { get; set; }     
    public int? FamilyHistoryID { get; set; } 
    public int? PersonId { get; set; }    
    public DateTime? ReportDate { get; set; }  
    public string PhysicianName { get; set; }  
    public string MRNumber { get; set; } 
    public virtual F_FamilyHistory F_FamilyHistory { get; set; } 
    public virtual Person Person { get; set; } 

    public virtual ICollection<CP_ActualDischarge> CP_ActualDischarges { get; set; } 
    public virtual ICollection<CP_Barrier> Barriers { get; set; } 
    public virtual ICollection<CP_AgencyContact> AgencyContacts { get; set; } 
    public virtual ICollection<CP_DischargeActivity> DischargeActivities { get; set; } 
    public virtual ICollection<C_Role> Roles { get; set; } 
    public virtual ICollection<Case_Person_RD1> Case_Person_RD1s { get; set; } 
    public virtual ICollection<PHTSY_CensusCode> PHTSY_CensusCodes { get; set; }  
} 

public class CP_ActualDischarge 
{ 
    public int Id { get; set; } 

    [ForeignKey("Case_PHTSY")] 
    public int Case_PHTSYId{ get; set; } 

    ... 

    public virtual Case_PHTSY Case_PHTSY { get; set; } 
} 

public partial class CP_Barrier 
{ 

    [Key] 
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)] 
    public int Id { get; set; } 

    public int? Case_PHTSYId { get; set; } 

    ... 

    public virtual Case_PHTSY Case_PHTSY { get; set; } 

} 


public partial class CP_AgencyContact 
{ 
    [Key] 
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)] 
    public int Id { get; set; } 

    public int Case_PHTSYId { get; set; }    
    ... 

    public virtual Case_PHTSY Case_PHTSY { get; set; } 

} 

public partial class CP_DischargeActivity 
{ 

    [Key] 
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)] 
    public int Id { get; set; } 

    public int? Case_PHTSYId { get; set; } 

    ...    

    public virtual Case_PHTSY Case_PHTSY { get; set; } 

} 

public partial class C_Role 
{ 
    [Key] 
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)] 
    public int Id { get; set; } 

    public int? Case_PHTSYId{ get; set; } 
    public virtual Case_PHTSY Case_PHTSY { get; set; } 
} 

}

public partial class Case_Person_RD1 
{ 
    public virtual C_Role C_Role { get; set; } 

    public virtual Case_PHTSY Case_PHTSY { get; set; } 
} 

外部キー:

ALTER TABLE [dbo].[CP_ActualDischarge] WITH NOCHECK ADD CONSTRAINT   [FK_CP_ActualDischarge_Case_PHTSY] FOREIGN KEY([Case_PHTSYId]) 
    REFERENCES [dbo].[Case_PHTSY] ([Id]) 
    ON DELETE CASCADE 
    NOT FOR REPLICATION 
    GO 
    ALTER TABLE [dbo].[CP_ActualDischarge] CHECK CONSTRAINT [FK_CP_ActualDischarge_Case_PHTSY] 

    ALTER TABLE [dbo].[CP_AgencyContacts] WITH NOCHECK ADD CONSTRAINT   [FK_CP_AgencyContacts_Case_PHTSY] FOREIGN KEY([Case_PHTSYId]) 
    REFERENCES [dbo].[Case_PHTSY] ([Id]) 
    ON DELETE CASCADE 
    NOT FOR REPLICATION 
    GO 
ALTER TABLE [dbo].[CP_AgencyContacts] CHECK CONSTRAINT [FK_CP_AgencyContacts_Case_PHTSY] 

    ALTER TABLE [dbo].[CP_Barriers] WITH NOCHECK ADD CONSTRAINT  [FK_CP_Barriers_Case_PHTSY] FOREIGN KEY([Case_PHTSYId]) 
REFERENCES [dbo].[Case_PHTSY] ([Id]) 
ON DELETE CASCADE 
NOT FOR REPLICATION 
GO 
ALTER TABLE [dbo].[CP_Barriers] CHECK CONSTRAINT [FK_CP_Barriers_Case_PHTSY] 

ALTER TABLE [dbo].[CP_DischargeActivities] WITH NOCHECK ADD CONSTRAINT [FK_CP_DischargeActivities_Case_PHTSY] FOREIGN KEY([Case_PHTSYId]) 
REFERENCES [dbo].[Case_PHTSY] ([Id]) 
ON DELETE CASCADE 
NOT FOR REPLICATION 
GO 
ALTER TABLE [dbo].[CP_DischargeActivities] CHECK CONSTRAINT [FK_CP_DischargeActivities_Case_PHTSY] 
GO 


     modelBuilder.Entity<Case_PHTSY>().HasMany(c => c.AgencyContacts).WithOptional().HasForeignKey(k => k.Case_PHTSYId); 
      modelBuilder.Entity<Case_PHTSY>().HasMany(c => c.Barriers).WithOptional().HasForeignKey(k => k.Case_PHTSYId); 
      modelBuilder.Entity<Case_PHTSY>().HasMany(r => r.DischargeActivities).WithOptional().HasForeignKey(k => k.Case_PhstsyId); 
      modelBuilder.Entity<Case_PHTSY>().HasMany(c => c.Roles).WithOptional().HasForeignKey(k => k.Case_PHTSYId); 
      modelBuilder.Entity<Case_PHTSY>().HasMany(m => m.Case_Person_RD1s).WithOptional().HasForeignKey(k => k.Case_PhtsyId); 
      modelBuilder.Entity<Case_PHTSY>().HasMany(o => o.DischargeActivities).WithOptional().HasForeignKey(k => k.Case_PhstsyId); 
      modelBuilder.Entity<Case_PHTSY>().HasOptional(o => o.F_FamilyHistory).WithRequired(); 
      modelBuilder.Entity<Case_PHTSY>().HasMany(o => o.PHTSY_CensusCodes).WithOptional().HasForeignKey(k => k.Case_PHTSYId); 



the primary table: 
CREATE TABLE [dbo].[Case_PHTSY](
    [Id] [int] IDENTITY(5000,1) NOT FOR REPLICATION NOT NULL, 
    [FamilyHistoryID] [int] NULL, 
    [IntensityNHours] [smallint] NULL, 
    [IEPRequested] [bit] NULL CONSTRAINT [DF_Case_PHTSY_IEPRequested] DEFAULT (0), 
    ... 
    [Kidnet] [bit] NULL, 
CONSTRAINT [PK_Case_PHTSY] PRIMARY KEY CLUSTERED 
(
    [Id] ASC 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
) ON [PRIMARY] 

GO 
SET ANSI_PADDING OFF 
GO 
ALTER TABLE [dbo].[Case_PHTSY] WITH NOCHECK ADD CONSTRAINT [FK_Case_PHTSY_F_FamilyHistory] FOREIGN KEY([FamilyHistoryID]) 
REFERENCES [dbo].[F_FamilyHistory] ([FamilyHistoryID]) 
ON DELETE CASCADE 
NOT FOR REPLICATION 
GO 
ALTER TABLE [dbo].[Case_PHTSY] CHECK CONSTRAINT [FK_Case_PHTSY_F_FamilyHistory] 
GO 
ALTER TABLE [dbo].[Case_PHTSY] WITH CHECK ADD CONSTRAINT [FK_Case_PHTSY_Persons] FOREIGN KEY([CaseChildID]) 
REFERENCES [dbo].[Persons] ([PersonID]) 
GO 
ALTER TABLE [dbo].[Case_PHTSY] CHECK CONSTRAINT [FK_Case_PHTSY_Persons] 

CREATE TABLE [dbo].[CP_ActualDischarge](
    [Id] [int] IDENTITY(1,1) NOT NULL, 
    [Case_PHTSYId] [int] NOT NULL, 
    [DischargeDate] [datetime] NULL, 

CONSTRAINT [PK_CP_ActualDischarge] PRIMARY KEY CLUSTERED 
(
    [Id] ASC 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
) ON [PRIMARY] 

GO 
SET ANSI_PADDING OFF 
GO 
ALTER TABLE [dbo].[CP_ActualDischarge] WITH NOCHECK ADD CONSTRAINT [FK_CP_ActualDischarge_Case_PHTSY] FOREIGN KEY([Case_PHTSYId]) 
REFERENCES [dbo].[Case_PHTSY] ([Id]) 
ON DELETE CASCADE 
NOT FOR REPLICATION 
GO 
ALTER TABLE [dbo].[CP_ActualDischarge] CHECK CONSTRAINT [FK_CP_ActualDischarge_Case_PHTSY] 

CREATE TABLE [dbo].[CP_AgencyContacts](
    [AgencyContactID] [int] IDENTITY(1,1) NOT FOR REPLICATION NOT NULL, 
    [Case_PHTSYId] [int] NOT NULL, 
    [AgencyType] [int] NULL, 
    [Agency] [int] NULL, 
CONSTRAINT [PK_Case_PHTSY_AgencyContacts] PRIMARY KEY CLUSTERED 
(
    [AgencyContactID] ASC 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
) ON [PRIMARY] 

GO 
SET ANSI_PADDING OFF 
GO 
ALTER TABLE [dbo].[CP_AgencyContacts] WITH NOCHECK ADD CONSTRAINT [FK_CP_AgencyContacts_Case_PHTSY] FOREIGN KEY([Case_PHTSYId]) 
REFERENCES [dbo].[Case_PHTSY] ([Id]) 
ON DELETE CASCADE 
NOT FOR REPLICATION 
GO 
ALTER TABLE [dbo].[CP_AgencyContacts] CHECK CONSTRAINT [FK_CP_AgencyContacts_Case_PHTSY] 

答えて

2

それだけでヘッドバンギングのもう1時間程度かかりましたが、私は解決策に来ました別の応答からのヒントを使用します。その欠点は、EntityFrameworkがいくつかの関係(または流暢な表現を使った私の記述が混乱していたこと)について混乱していたことです。

最後に弾丸を噛んで、データベースの列の名前をいくつか整理して、それらを「従来型」にしました。つまり、tableName + Idは流暢な式を削除しました。

私は1つのテーブルでコンポジットキーを取り出し、Idフィールドを追加してコンポジットキーをユニークなインデックスにしました。

私はこれが他の人に役立つことを願っています。

また、SQL Server 2008を使用しているときにIDの注釈が不要であるという疑いを確認しました。使用されているデータベースは、私は、同じエラーが発生した2005年

[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]

2

ました。最終的に、それを不正な関係にトレースしました。私はプライマリと外国のデータベースの代わりにデータベースの2つのプライマリキーをリンクしていました。

0

手動で.edmxの不正な参照を削除する必要がありました。

関連する問題