asp.net 数组排序
有两个数据库,一个是sql2000,一个是access.sql2000里有table1表,access有table2表,同样都有个datetime类型的字段.我现在要取这...
有两个数据库,一个是sql2000,一个是access.
sql2000里有table1表,access有table2表,
同样都有个datetime类型的字段.
我现在要取这两张表里按order by [datetime] desc 排序的前20条.
也就是两表都取前20条,然后放在一数组里面,数组里也就有40条记录了
根据 datatime 最新的来排序.
最终取 datatime 最新的20条记录.
我现在两个表的数据都取出来了,该怎么赋到数组里排序呢?
请高手赐教,比较急,在线等 ...
合并两个表后再通过排序显示前20条出来的. 展开
sql2000里有table1表,access有table2表,
同样都有个datetime类型的字段.
我现在要取这两张表里按order by [datetime] desc 排序的前20条.
也就是两表都取前20条,然后放在一数组里面,数组里也就有40条记录了
根据 datatime 最新的来排序.
最终取 datatime 最新的20条记录.
我现在两个表的数据都取出来了,该怎么赋到数组里排序呢?
请高手赐教,比较急,在线等 ...
合并两个表后再通过排序显示前20条出来的. 展开
4个回答
展开全部
不要用数组,C#中本身自带了支持排序的对象,比如SortedList、HashTable。
根据你的实际情况,因为你的数据是从数据库中获取,这里可以用DataTable和DataView来辅助你进行排序
//随机生成序列,你可以分别从SQL和Access中获取这两个DataTable
DataTable d1 = new DataTable();
DataTable d2 = new DataTable();
d1.Columns.Add("时间", typeof(DateTime));
d2.Columns.Add("时间", typeof(DateTime));
Random r = new Random();
for (int i = 0; i < 20; i++)
{
DataRow dr1 = d1.NewRow();
DataRow dr2 = d2.NewRow();
dr1["时间"] = DateTime.Today.AddDays(r.Next(1, 999));
dr2["时间"] = DateTime.Today.AddDays(r.Next(1, 999));
d1.Rows.Add(dr1);
d2.Rows.Add(dr2);
}
DataView dv1 = d1.DefaultView;
dv1.Sort = "时间 desc";
listBox1.DataSource = dv1;
listBox1.DisplayMember = "时间";
DataView dv2 = d2.DefaultView;
dv2.Sort = "时间 desc";
listBox2.DataSource = dv2;
listBox2.DisplayMember = "时间";
//把两个DataTable合并到一个
DataTable d3 = new DataTable();
d3.Columns.Add("时间", typeof(DateTime));
for (int i = 0; i < 20; i++)
{
d3.Rows.Add(d1.Rows[i].ItemArray);
d3.Rows.Add(d2.Rows[i].ItemArray);
}
//利用DataView排序
DataView dv3 = d3.DefaultView;
dv3.Sort = "时间 desc";
listBox3.DataSource = dv3;
listBox3.DisplayMember = "时间";
根据你的实际情况,因为你的数据是从数据库中获取,这里可以用DataTable和DataView来辅助你进行排序
//随机生成序列,你可以分别从SQL和Access中获取这两个DataTable
DataTable d1 = new DataTable();
DataTable d2 = new DataTable();
d1.Columns.Add("时间", typeof(DateTime));
d2.Columns.Add("时间", typeof(DateTime));
Random r = new Random();
for (int i = 0; i < 20; i++)
{
DataRow dr1 = d1.NewRow();
DataRow dr2 = d2.NewRow();
dr1["时间"] = DateTime.Today.AddDays(r.Next(1, 999));
dr2["时间"] = DateTime.Today.AddDays(r.Next(1, 999));
d1.Rows.Add(dr1);
d2.Rows.Add(dr2);
}
DataView dv1 = d1.DefaultView;
dv1.Sort = "时间 desc";
listBox1.DataSource = dv1;
listBox1.DisplayMember = "时间";
DataView dv2 = d2.DefaultView;
dv2.Sort = "时间 desc";
listBox2.DataSource = dv2;
listBox2.DisplayMember = "时间";
//把两个DataTable合并到一个
DataTable d3 = new DataTable();
d3.Columns.Add("时间", typeof(DateTime));
for (int i = 0; i < 20; i++)
{
d3.Rows.Add(d1.Rows[i].ItemArray);
d3.Rows.Add(d2.Rows[i].ItemArray);
}
//利用DataView排序
DataView dv3 = d3.DefaultView;
dv3.Sort = "时间 desc";
listBox3.DataSource = dv3;
listBox3.DisplayMember = "时间";
展开全部
Array.Sort(Array,Array);
第一个array放排序字段,第二个array放记录数组
第一个array放排序字段,第二个array放记录数组
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
List<string> sl = new List<string>();
sl.Add("Dataa");
sl.Add("Datab");
sl.Add("Datac");
SCompare sc = new SCompare();
sc.IsAsc = false; //正序为true 默认为true
sl.Sort(sc);
//建一个排序类
class SCompare : IComparer<string>
{
public bool IsAsc =true;
public int Compare(string xs, string ys)
{
int op = 1;
if (IsAsc) op = 1;
return xs.CompareTo(ys) * op;
}
}
sl.Add("Dataa");
sl.Add("Datab");
sl.Add("Datac");
SCompare sc = new SCompare();
sc.IsAsc = false; //正序为true 默认为true
sl.Sort(sc);
//建一个排序类
class SCompare : IComparer<string>
{
public bool IsAsc =true;
public int Compare(string xs, string ys)
{
int op = 1;
if (IsAsc) op = 1;
return xs.CompareTo(ys) * op;
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
主要是合并,学过数据结构就知道用两个栈比较后往第三个里面放,不好意思,现在没空给你写例程,大概就是这意思
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询