我有一个包含拆分阵列到另一个阵列
- 的
Price
- 的
Code
我已经成功地列表划分到一个数组,但我想一个列表进一步拆分阵列,以便我可以分别得到Price
和Code
并按升序对Price
进行排序。当分类发生时,我需要Code
也一起排序,因为Price
是针对特定的Code
。
因此,这将是这样的: 原版:
1588,8DNY;1488,ACNY;1288,7DPE;1888,8HUC;1488,8WNH;
后拆分到arrPrice:
[1588,8DNY],[1488,ACNY],[1288,7DPE],[1888,8HUC],[1488,8WNH]
第二分割2ndarrPrice:
[1588],[1488],[1288],[1888],[1488]
第二分割2ndarrCode:
按升序排列[8DNY],[ACNY],[7DPE],[8HUC],[8WNH]
排序价格:
[1288],[1488],[1488],[1588],[1888]
号码将被相应地进行排序:
[7DPE],[ACNY],[8HUC],[8WNH]
我第一次分裂后卡住。
if (lblprices.Text != "")
{
arrprice = lblprices.Text.Split(new char[] { ';' }, StringSplitOptions.RemoveEmptyEntries);
Array.Sort(arrprice);
for (i = 0; i < arrprice.Length; i++)
{
arr2 = arrprice[i].Split(',');
SQL2 = "SELECT DISTINCT [TP].[TCode], ";
SQL2 += "[TP].[TName], ";
SQL2 += "[TP].[TName_CN], ";
SQL2 += "[TP].[TourType], ";
SQL2 += "[TP].[LastUpdateDate], ";
SQL2 += "[TP].[ValidityFrom], ";
SQL2 += "[TP].[ValidityTo], ";
SQL2 += "[CL].[CountryCode], ";
SQL2 += "[CL].[CityName] ";
SQL2 += "FROM [CL], [TP], [TourItinerary],[TourHotel] ";
SQL2 += "WHERE [TP].[Activation] = 1 ";
SQL2 += "AND [TP].[TCode] = '" + arr2[1] + "' ";
SQL2 += "ORDER BY [TP].[LastUpdateDate] DESC ";
objConnTour.Open();
SqlCommand command = new SqlCommand(SQL2, objConnTour);
SqlDataReader dataReader = command.ExecuteReader();
if (dataReader.Read())
{
html += "<tr><td class=\"border\">" + dataReader["TCode"] + "</td>";
html += "<td class=\"border\">" + dataReader["TName"] + "</td>";
html += "<td class=\"border\">" + dataReader["TName_CN"] + "</td>";
html += "<td class=\"border\">" + dataReader["TType"] + "</td>";
html += "<td class=\"border\">" + dataReader["LastUpdateDate"] + "</td>";
html += "<td class=\"border\">" + dataReader["ValidityFrom"] + "</td>";
html += "<td class=\"border\">" + dataReader["ValidityTo"] + "</td>";
html += "<td class=\"border\">" + dataReader["CountryCode"] + "</td>";
html += "<td class=\"border\">" + dataReader["CityName"] + "</td>";
html += "<td class=\"border\">from <span class=\"price-red\">S$<b>" + arr2[0] + "</b></span><td/></tr>";
}
dataReader.Close();
objConnTour.Close();
}
}
return html;
上面的代码将无法按升序对价格进行排序。正如你可以在我的arr2
拆分看到的,我需要Code
和Price
在一起,因为我将基于Code
从数据库中检索数据。
-------- ---------编辑
确定这样的问题是,如果价格都在1000-1999的,它就会被完全排序。 但是,如果我有价格小于1000,它不会被以升序方式
实施例通过@jekcom
这是当我有没有排序是使用所提供的代码的结果的屏幕截图拆分列表,并检索他们从数据库
生,这是一个排序使用@ jekcom的代码
请注意价格未按升序排序。
你能指出确切位置,你会得到一个错误/不工作? – 2pietjuh2
jekcom的回答是错误的。请参阅我的代码或电子邮件 – nawfal
修复复制器,立即尝试 – jekcom