在實體框架中抑制自動主鍵產生
實體框架的程式碼優先方法通常會自動產生主鍵,特別是自動遞增識別列。 這種自動行為並不總是合適的。 本文概述如何覆寫此預設功能。
一種常見方法使用流暢的 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中文網其他相關文章!