2012-03-18 10 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 again .... !!! !!!あなたは私の一日を保存:) –

関連する問題