C#解决Linq OrderBy() 失效的小技巧

2018-06-18 02:25:01来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

前言

      前几天的一个数据列表中我用了Linq GroupBy 和OrderBy。 排序在本机正常使用,发到测试后排序死活不对,很是郁闷,总以为是程序问题。于是请教了另外一个同事。有了以下的答案。

 

问题原因和解决方法

    因为服务器装的是英文版操作系统,没有中文包,所以碰见中文排序无法识别,所以使用OrderBy时需要单独处理下。

 

CultureInfo culture = CultureInfo.GetCultureInfo("zh-cn");

            List<TeamDto> teamDtos = teams
                    .GroupBy(x => new
                    {
                        x.TestId,
                        x.TestName
                    })
                    .Select(g => new TeamDto()
                    {
                        TestID = g.Key.TestId,
                        Test = g.Key.TestName,
                        Teams = g.ToList()
                    })
                    .OrderBy(t=>t.Test,StringComparer.Create(culture,true))
                    .ToList();

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:ADO.NET provider with invariant name &#39;System.Data.Sq

下一篇:数据库中最简单最原始的聚合函数