首頁 >資料庫 >mysql教程 >LINQ 可以在不先選擇資料的情況下執行直接 SQL 更新嗎?

LINQ 可以在不先選擇資料的情況下執行直接 SQL 更新嗎?

Patricia Arquette
Patricia Arquette原創
2024-12-25 05:26:171031瀏覽

Can LINQ Perform Direct SQL Updates Without Selecting Data First?

使用 LINQ 直接更新而不使用 Select

直接處理 SQL 時,您可以使用條件來產生更新指令,而無需執行 select 語句。在 LINQ 中,常見模式涉及選擇實體、修改它們以及提交變更。但是,是否可以使用 LINQ 和延遲執行執行直接更新而不將資料傳輸到客戶端?

提供的 LINQ 查詢嘗試執行直接更新,但它包含 select 子句。雖然 LINQ 具有產生更新命令所需的所有信息,但 LINQ 中沒有等效的「set」關鍵字。

解決方案:

使用以下指令建立直接更新語句LINQ-to-SQL:

  1. 建立對象並設定其鍵屬性:
Foo foo = new Foo { FooId = fooId };
  1. 將物件附加到上下文:
context.Foos.Attach(foo);
  1. 設定要更新的屬性:
foo.Name = "test";
  1. 提交更改:
context.SubmitChanges();

注意:

  • 注意:
  • 注意:
要將屬性設為 null,請使用非 null 值初始化物件(例如, Name="###")。 要在更新時檢查時間戳,請將 Dbml 中 Modified 屬性的 UpdateCheck 屬性設為「始終」。

以上是LINQ 可以在不先選擇資料的情況下執行直接 SQL 更新嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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