OData WebAPI實踐-Non-EDM模式

来源:https://www.cnblogs.com/podolski/archive/2023/05/12/17395382.html
-Advertisement-
Play Games

本文屬於OData系列文章 前文說到了 EDM 與 OData 之間的關係,具有 EDM 的 OData 提供了強大的查詢能力,但是 OData 並不必須要配置 EDM,我們也可以使用 Non-EDM 方案。 Non-EDM 所謂 Non-EDM ,並不是說在 OData 運行時不需要 EDM 配置 ...


本文屬於OData系列文章

前文說到了 EDMOData 之間的關係,具有 EDMOData 提供了強大的查詢能力,但是 OData 並不必須要配置 EDM,我們也可以使用 Non-EDM 方案。

Non-EDM

所謂 Non-EDM ,並不是說在 OData 運行時不需要 EDM 配置了,而是由 OData 動態生成的 EDM,進而實現 OData 功能。

配置

配置 OData 就可以不需要在內配置 GetEdmModel()。當然,如果你需要配置路由,因為函數參數需要,我們可以返回一個預設的空 EDM。

            services.AddControllers()
                .AddOData(opt => opt.Count().Filter().Expand().Select().OrderBy().SetMaxTop(5)
                );

控制器

為了實現 OData 的功能,我們依然需要給控制器與函數上增加一些配置:

	[ApiController]
    [Route("api/[controller]")]
    public class AccountsController : ControllerBase
    {
        [HttpGet]
        public IActionResult Get(ODataQueryOptions<Account> queryOptions)
        {
            var querable = accounts.AsQueryable<Account>();
            var finalQuery = queryOptions.ApplyTo(querable);
            return Ok(finalQuery);
        }

        [HttpGet("{id}")]
        public IActionResult Get(Guid id, ODataQueryOptions<Account> queryOptions)
        {
            var accountQuery = accounts.Where(c => c.AccountId == id);
            if (!accountQuery.Any())
            {
                return NotFound();
            }

            var finalQuery = queryOptions.ApplyTo(accountQuery.AsQueryable<Account>()) as IQueryable<dynamic>;
            var result = finalQuery.FirstOrDefault();

            if (result == null)
            {
                return NotFound();
            }

            return Ok(result);
        }
    }

這裡代碼使用了 ODataQueryOptions,因此沒有使用 [EnableQuery]

我們查看 OData 路由,Account 不在路徑中了。
image

但是我們還是可以使用 OData 語法來進行查詢:

image

細心的同學發現:

  • 我使用了 $count,但是返回的內容並沒有計數結果。
  • 返回對象中沒有 @odata.context 指示對應實體的 EDM 配置信息。
  • 在定義了 OData EDM 的對象中,返回數組類型是 "Value":[] 的形式,而沒有定義 EDM 的對象會直接返回數組對象,這個在與前端進行交互的過程中需要特別註意。

限制

不使用 EDM 模式,在使用 OData 查詢時還是有很多限制:

  • 類似$count 之類的語句暫時還不支持。
  • 不支持複雜對象(ComplexType)的 $select。
  • 無法配置 EntityType 的 Ignore ,不支持一些 OData 的高級特性。
  • 不能實現 OData Routing 映射,可能會造成 Versioning 之類的操作困難。

因此,還是建議在使用 OData 時使用並正確配置 EDM,這樣可以獲得最全面的 OData 特性支持。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 單選題 Thread類中能運行線程體的方法是B.run( )。start( )方法會啟動一個新的線程,init( )方法是構造器的一部分,resume( )方法是恢復一個暫停的線程。 如果要把容器空間分成東、西、南、北、中五個區域,應採用的佈局是D.BorderLayout。BorderLayout ...
  • 總覽 第1章 主要通過一個簡單的C語言程式介紹了一些基本元素,如:註釋,main函數等,用於快速瞭解C語言的大致結構和語法規則; 第2章 介紹了在C語言的運行環境以及C語言中的標識符; 第3章 主要講解了C語言中基礎的數據類型,如整型、浮點型等,以及變數的作用域和屬性等重要知識; 第4章 介紹了C語 ...
  • 背景😎 工欲善其事,必先利其器。掌握Go的基礎語法還不夠,還需要勤加練習,修習“外功”,才能達到出奇制勝的效果。 在大致瞭解Go語言的基本語法後,我就迫不得已地想使用這門語言。可是我發現編程思路不是問題,很大的問題是“手慢”,不熟悉常用寫法(可能這就是快速過語法的缺點吧,腦子會了,手沒會)φ(* ̄ ...
  • 1. 前言 最近又開始寫論文,記錄一下使用Latex製作表格的方法 2.不同類型表格製作 2.1最基本的無線表格: tabbing 利用製表位進行表格的排版, 但是不會出現表線, 另外這個環境對於製表位比較靈活, 需要考慮很多因素(製表位的相對位置)才能製作出一個精美的表格. 一般來說不是很常用. ...
  • Spring Spring 核心學習內容 IOC、AOP、 JdbcTemplate、聲明式事務 1.Spring 幾個重要概念 Spring 可以整合其他的框架(Spring 是管理框架的框架) Spring 有兩個核心的概念: IOC 和 AOP IOC Inversion Of Control ...
  • 🚀 jdbc-plus簡介 🚀 jdbc-plus是一款基於JdbcTemplate增強工具包, 基於JdbcTemplate已實現分頁、多租戶、動態表名等插件,可自定義擴展插件,可與mybatis、mybatis-plus等混合使用。項目地址:https://github.com/deerou ...
  • 如何從一個小白快速開始入手看論文,然後看論文,發論文。請仔細看下麵的講解。歡迎大家一起交流和補充。 閱讀論文的方法和技巧 一.閱讀論文五個重要步驟(通常用時30-60分鐘) 1.第一遍是快速瀏覽論文的摘要、結論、框架圖,有助於把握核心,對論文的內容形成整體感知。(5-10分鐘) 當然,這一遍建議在網 ...
  • 如果類的對象的數量只有有限個,並且可以確定對象的屬性,那麼考慮使用枚舉類。所有的枚舉類型都是 Enum 類的子類。它們繼承了這個類的許多方法。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...