簡體   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