在C#中,您认为最快的方法是什么?代码最终将成为SQL Server CLR C#用户定义函数的一部分,但我认为这对于这个问题并不重要。
INPUT: "1,3,2,5,4"
OUTPUT: "1,2,3,4,5"
排序必须通过比较数字作为整数而不是字符串或字符来完成。
我目前有以下内容,但它是基于字符串排序,而不是整数。我可以介绍一个自定义的比较器,但我会问这个问题,看看其他人是否有任何想法。
[Microsoft.SqlServer.Server.SqlFunction]
public static SqlString udfSortDimensionValueIDString(SqlString DimensionValueIDs)
{
string[] values = ((string)DimensionValueIDs).Split(',');
Array.Sort(values);
return String.Join(",", values);
}
如果重要,请使用.NET 3.5。
答案 0 :(得分:11)
您可以使用 Linq :
using System.Linq; // no include required, just uses the namespace
...
String Input = "1,3,2,5,4";
String Output = String.Join(",", Input
.Split(',')
.Select(x => int.Parse(x))
.OrderBy(x => x));
答案 1 :(得分:2)
string s = "1,3,2,5,4";
string ordered = String.Join(",", s.Split(',').Select(c => Convert.ToInt32(c)).OrderBy(i=>i));
答案 2 :(得分:0)
您可以在逗号上拆分字符串,并使用Convert库将每个字符串转换为数字。 http://msdn.microsoft.com/en-us/library/bb397679.aspx