2012-03-18 53 views
3

我试图显示在VS 2008中使用datagridview从sql数据库检索到的数据集。但我需要垂直显示数据而不是水平显示数据。这是我在开始时所做的。如何在DataGridView中将行显示为列?

con.Open(); 
SqlCommand cmd = new SqlCommand("proc_SearchProfile", con); 
cmd.CommandType = CommandType.StoredProcedure; 
cmd.Parameters.Add("@scute_id", SqlDbType.VarChar, (10)).Value = val; 
SqlDataAdapter adapt = new SqlDataAdapter(cmd); 
DataSet dset = new DataSet(); 

adapt.Fill(dset, "Profile"); 
this.dataGridView1.DataSource = dset; 
this.dataGridView1.DataMember = "Profile"; 

我搜索并阅读了一些线程,但没有一个工作。任何人都可以帮助我垂直显示在datagridview中检索到的数据?

回答

9

试试这个:

var tbl = dset.Tables["Profile"]: 
var swappedTable = new DataTable(); 
for (int i = 0; i <= tbl.Rows.Count; i++) 
{ 
    swappedTable.Columns.Add(Convert.ToString(i)); 
} 
for (int col = 0; col < tbl.Columns.Count; col++) 
{ 
    var r = swappedTable.NewRow(); 
    r[0] = tbl.Columns[col].ToString(); 
    for (int j = 1; j <= tbl.Rows.Count; j++) 
     r[j] = tbl.Rows[j - 1][col]; 

    swappedTable.Rows.Add(r); 
} 
dataGridView1.DataSource = swappedTable; 
+0

非常感谢蒂姆。那就像魅力一样。 Thnx再次.... !!!你拯救我的一天:) – 2012-03-18 12:47:17

相关问题