我有两张桌子有复合pk' s。 TABLE1的pk进入表2并且它们具有一对一的可选关系,即TABLE1可以具有1个TABLE2或0个TABLE2。当我插入数据时,我在模型创建时遇到以下异常。
指定的关联外键列' third_table_id,fourth_table_id'无效。指定的列数必须与主键列的数量匹配。
任何帮助将不胜感激。表1的pk来自表3
我已将映射TABLE1定义为: #region PROPERTIES
Property(p => p.THIRDTABLEID).HasColumnName("third_table_id").HasDatabaseGeneratedOption(DatabaseGeneratedOption.None).IsRequired();
Property(p => p.FOURTHTABLEID).HasColumnName("fourth_table_id").HasDatabaseGeneratedOption(DatabaseGeneratedOption.None).IsRequired();
Property(p => p.SEQID).HasColumnName("Seq_ID").HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity).IsRequired();
#endregion PROEPRTIES
#region IGNORE
Ignore(p => p.RowState);
#endregion IGNORE
#region IGNORE
ToTable("dbo.TABLE1");
#endregion IGNORE
#region KEYS
// HasKey(t => new { t.THIRDTABLEID, t.FOURTHTABLEID });
HasKey(t => t.THIRDTABLEID);
HasKey(t => t.FOURTHTABLEID);
#endregion KEYS
#region RELATIONSHIPS
//relationship
HasRequired(t => t.THIRDTABLEID).WithMany(c => c.TABLE1).HasForeignKey
(t => t.THIRDTABLEID).WillCascadeOnDelete(false);
//relationship
HasRequired(t => t.SESN).WithMany(c => c.TABLE1).HasForeignKey
(t => t.SESSIONID).WillCascadeOnDelete(false);
#endregion RELATIONSHIPS
和另一个TABLE2:
#region PROPERTIES
Property(p => p.BPROLEDETLID).HasColumnName("bp_role_detl_id").HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity).IsRequired();
Property(p => p.THIRDTABLEID).HasColumnName("third_table_id").HasDatabaseGeneratedOption(DatabaseGeneratedOption.None).IsRequired();
Property(p => p.FOURTHTABLEID).HasColumnName("fourth_table_id").HasDatabaseGeneratedOption(DatabaseGeneratedOption.None).IsRequired(); ;
Property(p => p.abc).HasColumnName("abc").IsOptional();
#endregion PROPERTIES
#region IGNORE
Ignore(p => p.RowState);
#endregion IGNORE
#region TABLE MAPPING
ToTable("dbo.TABLE2");
#endregion
#region KEYS
HasKey(t => new {t.THIRDTABLEID, t.FOURTHTABLEID});
//HasKey(t => t.THIRDTABLEID);
//HasKey(t => t.FOURTHTABLEID);
#endregion KEYS
#region RELATIONSHIPS
//relationship
HasRequired(t => t.TABLE1).WithOptional(c => c.TABLE1_DETL).Map(
m=> m.MapKey(
"third_table_id",
"fourth_table_id"
)).WillCascadeOnDelete(false);
#endregion RELATIONSHIPS
答案 0 :(得分:1)
您的第一个表使用HasKey两次,而不是创建复合键。第二个语句将覆盖第一个语句,因此看起来表1有一个主键,而表2有两列的组合键。这就是为什么它告诉你列数必须匹配的原因。