datatable 排序

来源:百度知道 编辑:UC知道 时间:2024/06/09 14:45:23
我用查询语句查询出三条记录放在datatable中,有三个字段,其中一个字段是summary。有一条记录的summary有值,其余记录的summary字段为空。
现在我希望根据summary字段排序,为空的放前面,有值的放后面。请问如何实现?谢谢!

DataTable dt = new DataTable();
dt.Columns.Add("Sum");
DataRow dr = dt.NewRow();
dr["Sum"] = 1;
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["Sum"] = 2;
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["Sum"] = 3;
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["Sum"] = 4;
dt.Rows.Add(dr);
dr = dt.NewRow();
dt.Rows.Add(dr);
dt.DefaultView.Sort = "Sum ASC";
DataTable dtTemp = dt.DefaultView.ToTable();
dtTemp 即按你需要排序的表。

改一下查询语句就可以了
string selectsql="select [字段1],[字段2],[summary] from [表名] order by [summary] desc ";
//前提是你的summary字段为自动编号类型或者数字类型,不然会出现错误

Over

用存储过程实现排序,封装代码。
也就是SQL语句中加一个order by,非常方便也很安全。
调用的时候把COMM