c# - 排序数据表在 C# ASP.NET 中不起作用?
问题描述
我正在尝试对数据表应用排序,但它正在工作。我想按distance
列应用排序。这是我的输出img
我想ASC
按从低到高的顺序排序。
代码:
SqlConnection cnn = new SqlConnection(connection);
string query = "SELECT PostCode,Latitude,Longitude FROM [kaykocou_admin].[kaykocou_admin].[Deals]";
SqlCommand cmd = new SqlCommand(query,cnn);
SqlDataAdapter adp = new SqlDataAdapter(cmd);
DataTable dt = new DataTable();
adp.Fill(dt);
DataTable dtnew = new DataTable();
DataRow _ravi;
if (dt.Rows.Count>0)
{
dtnew.Clear();
dtnew.Columns.Add("PostCode");
dtnew.Columns.Add("Lat");
dtnew.Columns.Add("Long");
// dtnew.Columns.Add("Lat 1");
// dtnew.Columns.Add("Long 1");
dtnew.Columns.Add("distance");
string str2 = GET("http://api.postcodes.io/postcodes/SW1A 0AA");
var serializer2 = new JavaScriptSerializer();
dynamic deserialize_post2 = serializer2.DeserializeObject(str2);
decimal Longitude1 = deserialize_post2["result"]["longitude"];
decimal Latitude1 = deserialize_post2["result"]["latitude"];
foreach (DataRow dr in dt.Rows)
{
string postcode = dr["PostCode"].ToString();
// string str1 = GET("http://api.postcodes.io/postcodes/" + postcode);
// string final = str1.Replace(@"{", "");
// string final2 = final.Replace(@"}", "");
// str1 = str1.Replace('[', ' ');
// str1 = str1.Replace(']', ' ');
// string result = "{ " + final2 + " }";
// var serializer = new JavaScriptSerializer();
// dynamic deserialize_post = serializer.DeserializeObject(str1);
decimal Longitude =Convert.ToDecimal( dr["Longitude"].ToString());
decimal Latitude =Convert.ToDecimal( dr["Latitude"].ToString()) ;
_ravi = dtnew.NewRow();
var sCoord = new GeoCoordinate(Convert.ToDouble(Latitude), Convert.ToDouble(Longitude));
var eCoord = new GeoCoordinate(Convert.ToDouble(Latitude1), Convert.ToDouble(Longitude1));
var distance=sCoord.GetDistanceTo(eCoord);
_ravi["PostCode"] = postcode;
_ravi["Lat"] = dr["Longitude"].ToString();
_ravi["Long"]= dr["Longitude"].ToString();
_ravi["distance"] =Convert.ToDouble( Math.Round(((distance / 1000.0) * 0.621371192), 2));
dtnew.Rows.Add(_ravi);
}
DataView view = dtnew.DefaultView;
view.Sort = "distance ASC";
DataTable sortedDate = view.ToTable();
//dtnew.DefaultView.Sort = "distance";
gr.DataSource = sortedDate;
gr.DataBind();
}
}
解决方案
推荐阅读
- java - 如何从 CSR(证书签名请求)中检索域?
- java - 在 Java 公历中设置语言环境
- ionic-framework - PopoverController离子4?
- django - DRF 嵌套路由器无法解析超链接关系的 URL
- ansible - 如何使用 ansible 2.5 和 python 2/3 从“ansible_default_ipv4”获取“地址”
- spring - 如何通过链接开始 Spring Webflow
- .net - 获取 Chrome .Net 中打开的标签页的 URL
- c# - 无法更新实体框架中的对象
- javascript - 输入特定命令后如何停止执行我的 .js 应用程序?
- python - LSTM 对批处理中的状态做了什么?第一批的第二个元素是否从第一个元素的第一个元素继承状态?