1

EF4についてもう一度質問があります:)申し訳ありませんが、ネット上で何も見つかりません。

問題は、CTP5コードのみをマップに使用していることです(多対多)、どうすればよいですか?

しかし、私は昔ながらの方法でやっています。つまり、3つのテーブルがあります。

  1. ユーザー
  2. 企業。
  3. UsersToCompanies->(UserId、CompanyId)

これをどのようにマッピングすればよいですか。POCOからマッピングまで、コード例を見せていただければ幸いです。


ここに画像の説明を入力してください

これは私が受け取るエラーです...

This is my entities
public class User 
{
   public int UserId { get; set; }
   public int? UserRoleId { get; set; }
   public string UserName { get; set; }
   public string UserPassword { get; set; }
   public DateTime InsertDate { get; set; }
   public virtual UserRole UserRole { get; set; }

   //this is my many to many prop
   public virtual ICollection<Company> Companies { get; set; }
}

public class Company
{
   public int CompanyId { get; set; }
   public string CompanyNameHe { get; set; }
   public string CompanyNameEn { get; set; }
   public string CompanyParent { get; set; }
   public DateTime InsertDate { get; set; }

   //this is my many to many prop
   public virtual ICollection<User> Users { get; set; }
}

/*relationship map*/
public class UsersCompanies
{
   public int Id { get; set; } 
   public int UserId { get; set; } 
   public int CompanyId { get; set; } 
}
    //mapping
 public class CompanyMap :  BaseConfig<Company>
 {
    public CompanyMap()
    {
        /*Identity*/
        HasKey(c => c.CompanyId);
        Property(c => c.CompanyId).HasDatabaseGenerationOption(DatabaseGenerationOption.Identity).HasColumnName("COMPANY_ID");

        /*Have default values*/
        Property(c => c.InsertDate).HasDatabaseGenerationOption(DatabaseGenerationOption.Computed).HasColumnName("INSERT_DATE");

        /*simple scalars*/
        Property(c => c.CompanyNameHe).HasMaxLength(32).IsRequired().HasColumnName("COMPANY_NAME_HE");
        Property(c => c.CompanyNameEn).HasMaxLength(32).IsRequired().HasColumnName("COMPANY_NAME_EN");
        Property(c => c.CompanyParent).HasMaxLength(32).IsRequired().HasColumnName("COMPANY_PARENT");
        ToTable("CMS_COMPANY", "GMATEST");
    }
 }


public class UserMap : BaseConfig<User>
{
   public UserMap()
   {
       /*Identity*/
       HasKey(c => c.UserId);
       Property(c => c.UserId).HasDatabaseGenerationOption(DatabaseGenerationOption.Identity).HasColumnName("USER_ID");

       /*Have default values*/
       Property(c => c.InsertDate).HasDatabaseGenerationOption(DatabaseGenerationOption.Computed).HasColumnName("INSERT_DATE");

       /*simple scalars*/
       Property(c => c.UserName).HasMaxLength(25).IsRequired().HasColumnName("USER_NAME");
       Property(c => c.UserPassword).HasMaxLength(25).IsRequired().HasColumnName("USER_PASSWORD");
       Property(c => c.UserRoleId).IsRequired().HasColumnName("USER_ROLE_ID");

       /*relationship*/
       HasRequired(u => u.UserRole).WithMany().HasForeignKey(t => t.UserRoleId);


       HasMany(p => p.Companies).WithMany(c => c.Users).Map(mc =>
       {
           mc.ToTable("UsersCompanies");
           mc.MapLeftKey(p => p.UserId, "CompanyId");
           mc.MapRightKey(c => c.CompanyId, "UserId");
       });
       ToTable("CMS_USERS", "GMATEST");
   }
}

public class UsersCompaniesMap : BaseConfig<UsersCompanies>
{
   public UsersCompaniesMap()
   {
       /*Identity*/
       HasKey(k => k.Id);
       Property(c => c.Id).HasDatabaseGenerationOption(DatabaseGenerationOption.Identity).HasColumnName("ID");

       Property(c => c.UserId).IsRequired().HasColumnName("USER_ID");
       Property(c => c.CompanyId).IsRequired().HasColumnName("COMPANY_ID");

       ToTable("CMS_USERS_TO_COMPANIES", "GMATEST");
   }
}

これが私が得るエラーです:

'((new System.Linq.SystemCore_EnumerableDebugView(ctx.FindAll()))。Items [0])。Companies'はタイプ'System.Data.EntityCommandExecutionException'の例外をスローしました

内部例外:ORA-00942:表またはビューが存在しません

4

2 に答える 2

1

マッピングを実行するために実際には3つのテーブルは必要ありません。あなたは単に次のことをすることができます:

public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public virtual ICollection<Company> Companies { get; set; }
}

public class Company
{
    public int Id { get; set; }
    public string Name { get; set; }
    public virtual ICollection<User> Users { get; set; }
}

そして、これはそれを行う必要があります。両方のPOCOで他のエンティティを参照する仮想ICollectionがある限り、CTP5の規則ですべてを処理する必要があります。一方、Fluent APIを使用して手動で行う場合は、ADO.NETチームによるこのブログを確認してください(多対多の関係のセクションまで少し下にスクロールしてください)。

于 2011-03-06T13:31:39.133 に答える
0

私の問題に対する答えは、皆さんに感謝しなければなりませんが、DevartのAndreyが解決策を教えてくれました。それは簡単です。

まず最初に、Companies、Users、UsersCompanies/の3つのテーブルが必要です。

次に、テーブルをテーブルの元の名前にマップする必要があります。例:私のusersテーブルはDbで次のように呼び出されます:CMS_USERS元の名前でマップする必要があります。これは私が使用する例であり、実際に機能します。

HasMany(c => c.Companies)
          .WithMany(u => u.Users)
          .Map(mc =>
          {
              mc.ToTable("CMS_USERS_TO_COMPANIES", "GMATEST");
              mc.MapLeftKey(c => c.UserId, "USER_ID");
              mc.MapRightKey(u => u.CompanyId, "COMPANY_ID");
          });

皆さん、ありがとうございました。

于 2011-03-12T21:20:01.057 に答える