欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

解决C#中Linq GroupBy 和OrderBy失效的方法

程序员文章站 2022-04-15 09:38:01
发现问题 在一个数据列表中我用了linq groupby 和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();

总结

以上就是这篇文章的全部内容了,希望能对同样遇到这个问题的朋友们有所帮助,如果有疑问大家可以留言交流。