2

我有一个包含相应名称和分数的数据表。我想根据分数降序排序。

这是 DB.cs 中的代码:

public class DB
    {
        public DataTable GetData()
        {
            string spName = "GetTime";
            Connection.Open();

            SqlCommand command = new SqlCommand(spName, Connection);
            command.CommandType = CommandType.StoredProcedure;

            SqlDataReader reader = command.ExecuteReader();
            DataTable dt = new DataTable();
            dt.Columns.Add("Name");
            dt.Columns.Add("Time");

            while (reader.Read())
            {
                DataRow dr = dt.NewRow();
                dr["Name"] = Convert.ToString(reader["name"]);
                dr["Time"] = Convert.ToInt32(reader["timeScore"]);
                dt.Rows.Add(dr);
            }
            Connection.Close();
            return dt;
        }
    }

这是在 Form3.cs 上

public partial class Form3 : Form
    {
        private Form2 form2;
        public Form3()
        {
            InitializeComponent();
            loadData();
        }

        public void loadData()
        {
            form2 = new Form2(); 
            DataTable dt2 = form2.db.GetData();
            dgvScore.DataSource = dt2;
        }
    }

comparer在Java中没有任何类似的东西我应该怎么做才能对其进行排序?我只想要一个简单的算法答案。感谢您的赞赏帮助!

4

2 回答 2

10

您无需遍历阅读器:

SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
DataTable dt = new DataTable();
dt.Load(dr);

然后你可以简单地对defaultView进行排序:

dt.DefaultView.Sort = "timeScore desc";
于 2013-07-14T18:16:07.170 回答
0

DataView当您想对 a 进行排序时,必须处理 a 有点不雅,DataTable所以这里有一个非常简单明了的对DataTableinstance 进行排序的方法。我不认为简洁会破坏语义清晰度,但如果您认为它令人困惑,请发表评论。

dt = new DataView(dt, "", "timeScore DESC",
                     DataViewRowState.CurrentRows).ToTable()
于 2016-07-01T18:55:49.327 回答