首頁 >後端開發 >C++ >如何防止實體框架自動產生主鍵?

如何防止實體框架自動產生主鍵?

Barbara Streisand
Barbara Streisand原創
2025-01-14 09:56:43441瀏覽

How to Prevent Entity Framework from Automatically Generating Primary Keys?

在實體框架中抑制自動主鍵產生

實體框架的程式碼優先方法通常會自動產生主鍵,特別是自動遞增識別列。 這種自動行為並不總是合適的。 本文概述如何覆寫此預設功能。

一種常見方法使用流暢的 API 配置:

<code class="language-csharp">modelBuilder.Entity<Event>().Property(e => e.EventID).HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);</code>

但是,這可能會導致錯誤:「當 IDENTITY_INSERT 設定為 OFF 時,無法在表格「Events」中插入識別列的明確值。」

理解錯誤

此錯誤是由衝突引起的。 DatabaseGeneratedOption.None 阻止 EF 產生 ID,但資料庫表仍然擁有 IDENTITY 屬性,在嘗試手動指派鍵值時會產生衝突。

解析度

解決方案涉及停用資料庫中 ID 列的 IDENTITY 屬性。 使用此 SQL 命令:

<code class="language-sql">ALTER TABLE Events ALTER COLUMN EventID INT NOT NULL</code>

基於屬性的替代方案

或者,您可以直接在實體類別中使用性別:

<code class="language-csharp">[Key]
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int EventID { get; set; }</code>

此方法在 EF Core 中也能正常運作。

透過實作這些解決方案,開發人員可以控制主鍵分配、手動指定值並繞過 EF 的預設自動產生。

以上是如何防止實體框架自動產生主鍵?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn