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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#解决Linq OrderBy() 失效的小技巧相关的知识,希望对你有一定的参考价值。

前言

前几天的一个数据列表中我用了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();

以上是关于C#解决Linq OrderBy() 失效的小技巧的主要内容,如果未能解决你的问题,请参考以下文章

请教linq中orderby子句与where子句共存时排序失效问题

快速回顾C#基础(编程的小技巧)待完善

C# LINQ Orderby - 真/假如何影响 orderby?

将 orderby 应用于 C# LINQ 内连接

c# linq Distinct 过滤重复项怎么做啊

EF(Linq)框架使用过程中的小技巧汇总 dbfunctions