首頁 > 後端開發 > C++ > 如何使用 LINQ 分割區實現群組內的行編號?

如何使用 LINQ 分割區實現群組內的行編號?

DDD
發布: 2024-12-30 06:50:10
原創
665 人瀏覽過

How to Implement Row Numbering within Groups Using LINQ Partitioning?

使用LINQ 分區進行行編號

給定一個填充了音樂家及其樂器的DataTable,我們希望使用以下命令來模擬MSSQL 查詢的功能LINQ 決定每個樂器組內的位置順序。

中LINQ,我們可以透過分組和選擇操作的組合來完成此操作:

var orderedBeatles = from b in beatles
                    group b by b.inst into instGroup
                    select new
                    {
                        b.id,
                        b.inst,
                        b.name,
                        rn = instGroup.Count()
                    };
登入後複製

這裡,我們根據Beatles 的樂器(inst) 將他們分組,並使用Count () 方法來計算行號( rn) 對於每個儀器。然後,我們為每個 Beatle 建立一個匿名類型,包括原始屬性以及計算的行號。

此 LINQ 查詢產生以下輸出:

id |   inst   |   name  | rn
-----------------------------
 1 |  guitar  |  john   | 1
 2 |  guitar  |  george | 2
 3 |  guitar  |  paul   | 3
 4 |  drums   |  ringo  | 1
 5 |  drums   |  pete   | 2
登入後複製

此結果反映了預期的結果MSSQL 查詢的輸出,使用 LINQ 分區在儀器組內提供所需的行編號。

以上是如何使用 LINQ 分割區實現群組內的行編號?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板