繁体   English   中英

PostgreSQL:'uuid'的自动生成不适用于EntityFramework

[英]Postgresql: autogeneration of 'uuid' doesn't work with EntityFramework

我使用实体框架(POCO方法)在.NET中使用“ PostgreSql”。

我的目标是在数据库侧在数据库中生成ID(uuid)的数据库中创建新记录,并将生成的ID检索到服务器(这种情况与SQL Server完美配合)。

我的模型如下:

public class MyClass
{
   [Key]
   [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
   public Guid Id { get; set; }

   public string Name { get; set; }
}

在PostgreSql列中,“ Id”具有默认值“ uuid_generate_v4()”

当我尝试使用EF将新对象添加到数据库时,出现以下错误:

A null store-generated value was returned for a non-nullable member 'Id' of type...

我检查了EF发送到PostgreSQL的SQL查询:

INSERT INTO "public"."MyClass"("Name") VALUES ("Test");
SELECT currval(pg_get_serial_sequence('"public"."MyClass"', 'Id')) AS "Id"

第一个看起来不错。 如果执行该操作,则会在数据库中创建新行(具有新生成的ID)。第二行返回NULL,列的名称为“ Id bigint”。 看来,此功能仅适用于数字ID。

是否有可能使其适用于'uuid'类型的自动生成的列?

您没有编写使用的EF提供程序。 我认为它是npgsql。

根据最新消息,它应该返回Sql Erwin Brandstetter发布:

INSERT INTO public."MyClass"("Name") VALUES ("Test") RETURNING "Id";

这是sql生成器的相关部分: SqlInsertGenerator类AppendReturning方法

我会尝试使用最新版本的npgsql(甚至可以自己从源代码构建它)。

使用RETURNING子句进行简化:

INSERT INTO public."MyClass"("Name") VALUES ("Test") RETURNING "Id";

没有单独的SELECT ,所以没有关于匹配你的函数列的默认值混乱SELECT 更简单,更快,更清洁。

更多细节:
PostgreSQL下一个序列的值?

我假设您正在使用https://github.com/npgsql/Npgsql

我想知道您使用的是哪个版本,因为您可能是从源代码构建自己的dll,因为https://github.com/npgsql/Npgsql/pull/91尚未成为任何发行版的一部分...如果您樱桃-选择PR91,您可能还应该选择PR160 https://github.com/npgsql/Npgsql/pull/160 ,它可以完全解决您的问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM