EFコアでユニークな列に複数のNULLが含まれることを許可していますか?

c# ef-code-first entity-framework entity-framework-core

質問

私のエンティティは、nullにすることができるプロパティを持っています。しかし、もしそれがヌルでなければ、ユニークでなければならない。つまり、列は一意ですが、複数のNULLが可能です。

私はもう試した:

config.Property(p => p.ProductId).IsRequired(false);

私はこれをコア前のEFで動作させるのに苦労していることを覚えています。

これは可能ですか?エンティティを設定するにはどうすればよいですか?

受け入れられた回答

はい、あなたはEF Coreでそれをすることができます、ユニークインデックスはデフォルトでフィルターされたインデックスとして作成されるので(WHERE ... IS NOT NULL)

config.Entity<Product>()
        .HasIndex(b => b.ProductId)
        .IsUnique();

https://github.com/aspnet/EntityFramework/pull/2868



Related

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ