13

考虑这个迁移代码:

       CreateTable(
            "dbo.Document",
            c => new
                {
                    Id = c.Int(nullable: false, identity: true),
                    Doc = c.String(),
                    RowGuid = c.Guid(nullable: false),
                    Person_Id = c.Int(),
                })
            .PrimaryKey(t => t.Id)
            .ForeignKey("dbo.Person", t => t.Person_Id)
            .Index(t => t.Person_Id);

我想要RowGuidbe ROWGUIDCOL,并像这样定义(SQL):

 [RowGuid] [UNIQUEIDENTIFIER] not null RowGuidCol Unique default newid()

中的等效代码是EntityFramework/CodeFirst什么?解决办法是什么?

谢谢。

4

3 回答 3

3

我想你想要一个有FILESTREAM列的表。使用 EntityTypeConfiguration 提示 EF 可以生成正确的脚本,并且不需要您手动编辑它(EF Core 2.2)。

取这个样本实体:

public class FileEntity
{
    public Guid FileGuid { get; private set; }
    public byte[] Document { get; private set; }
}

而这个配置:

public class FileEntityConfiguration : IEntityTypeConfiguration<FileEntity>
{
    public void Configure(EntityTypeBuilder<FileEntity> builder)
    {
        builder
            .Property(m => m.Document)
            .HasColumnType("VARBINARY(MAX) FILESTREAM");

        builder
            .Property(m => m.FileGuid)
            .HasColumnType("UNIQUEIDENTIFIER ROWGUIDCOL")
            .IsRequired();

        builder
            .HasAlternateKey(m => m.FileGuid);
    }
}

EF 生成正确的迁移脚本:

FileGuid = table.Column<Guid>(type: "UNIQUEIDENTIFIER ROWGUIDCOL", nullable: false),
Document = table.Column<byte[]>(type: "VARBINARY(MAX) FILESTREAM", nullable: true)
于 2019-04-05T03:08:01.933 回答
2

看起来 ROWGUIDCOL 属性不能直接通过实体框架设置,但可以通过“创造性”将该属性注入到生成 SQL 中;-) 使用 storeType 参数(假设 storeType 确实允许您覆盖默认数据类型)。从原始问题的代码开始,尝试以下操作:

 CreateTable(
            "dbo.Document",
            c => new
                {
                    RowGuid = c.Guid(nullable: false, identity: true,  
                                     defaultValueSql: "newid()",
                                     storeType: "UNIQUEIDENTIFIER ROWGUIDCOL"),
                    Person_Id = c.Int()
                })
            .Index(t => t.RowGuid, true);

不幸的是,我没有办法对此进行测试,但鉴于以下 SQL 有效,我认为值得一试:

CREATE TABLE dbo.Test1
(
    Col1 INT NOT NULL,
    Col2 UNIQUEIDENTIFIER ROWGUIDCOL NOT NULL UNIQUE DEFAULT NEWID()
)

“唯一”要求是通过 Index() 方法中的第二个参数为“true”创建的唯一索引来实现的。

请注意,如果表已经有一个标有 IDENTITY 的列,则在 Guid() 方法中使用“identity: true”可能会出现一些问题。我发现了解决这种情况的相关问题:Entity Framework Code First Using Guid as Identity with another Identity Column

于 2013-11-12T20:35:59.690 回答
2

经过一番研究和四处询问,我认为这是不可能的。我在代码中解决它的方法是在新建对象时获取新的 GUID:

    public class MyPOCO {
           public MyPOCO() { 
                RowGuid = Guid.NewGuid();
           }
      //.....
   }

这样,当我向表中插入新行时,我总是会生成一个新的 GUID。我想念使用 ROWGUIDCOL 但 EF 确实让我的生活变得简单。

于 2013-11-12T17:53:52.180 回答