datagridview问题

shui8iuhs 2009-07-28 12:40:23
表:test
字段:a b c

测试数据如下:
a b c
1 1 1
2 2 2
3 3 3

写的SQL语句: select * from test where a=1

得到:
a b c
1 1 1


我需要实现的是,在datagridview里面,不是下面这种显示:
a b c
1 1 1

我要竖着显示:
a 1
b 1
c 1


请教大家,我应该怎么弄哦,才可以实现这种显示方式。
在此先谢谢啦。

...全文
183 30 打赏 收藏 转发到动态 举报
写回复
用AI写文章
30 条回复
切换为时间正序
请发表友善的回复…
发表回复
shui8iuhs 2009-07-29
  • 打赏
  • 举报
回复
哇,解决啦,还是改SQL语句比较好。结贴老。
多谢大家。
LQknife 2009-07-28
  • 打赏
  • 举报
回复
先行列装换一下 这种装换网上好多
lovvver 2009-07-28
  • 打赏
  • 举报
回复
不知道有没有这样的控件,可能有
要不你就不要用datagrid的自动绑定,手动绑定,或者使用listview来手动绑定,做一下行列转换就好了。
ginni215 2009-07-28
  • 打赏
  • 举报
回复
可以考虑不用datagridview,使用listView控件~
dyh2030557 2009-07-28
  • 打赏
  • 举报
回复
26楼正解..
zhaigates 2009-07-28
  • 打赏
  • 举报
回复
学习了
gaijf 2009-07-28
  • 打赏
  • 举报
回复
ding
msnadair 2009-07-28
  • 打赏
  • 举报
回复
 DataTable dt = new DataTable();
private void button1_Click(object sender, EventArgs e)
{
dt = MakeParentTable();
this.dataGridView1.DataSource = dt.DefaultView;

}
private DataTable MakeParentTable()
{
System.Data.DataTable table = new DataTable("ParentTable");

DataColumn column;
DataRow row;

column = new DataColumn();
column.DataType = System.Type.GetType("System.String");
column.ColumnName = "id";
table.Columns.Add(column);

column = new DataColumn();
column.DataType = System.Type.GetType("System.String");
column.ColumnName = "ParentItem";
column.AutoIncrement = false;
column.Caption = "ParentItem";

column.Unique = false;

table.Columns.Add(column);

DataColumn[] PrimaryKeyColumns = new DataColumn[1];
PrimaryKeyColumns[0] = table.Columns["id"];
table.PrimaryKey = PrimaryKeyColumns;

for (int i = 0; i <= 2; i++)
{
row = table.NewRow();
row["id"] = i.ToString();
row["ParentItem"] = "a" + i;
table.Rows.Add(row);
}

return table;
}

private DataTable Trans(DataTable dt)
{
if (dt != null)
{
DataTable tmpTable = dt;
DataRow dr = dt.NewRow();

for (int i = 0; i < dt.Columns.Count; i++)
{
string colName = dt.Columns[i].ColumnName;
dr[colName] = colName;
}

dt.Rows.InsertAt(dr,0);


DataTable newTable = new DataTable();
DataColumn column;
DataRow row;
// 新建一表,列数等于dt的行数
for (int m = 0; m < dt.Rows.Count; m++)
{
column = new DataColumn();
column.DataType = System.Type.GetType("System.String");
column.ColumnName = "column" + m;
newTable.Columns.Add(column);
}

// 新建行,行数等于dt的列数
for (int i = 0; i < dt.Columns.Count; i++)
{
row = newTable.NewRow();
newTable.Rows.Add(row);
}

// 将行列倒置
for (int col = 0; col < dt.Columns.Count; col++)
{
for (int n = 0; n < dt.Rows.Count; n++)
{
newTable.Rows[col][n] = dt.Rows[n][col];
}
}

return newTable;
}

return null;
}

private void button2_Click(object sender, EventArgs e)
{
DataTable mTable = Trans(dt);
this.dataGridView2.DataSource = mTable.DefaultView;
}

tylichao008 2009-07-28
  • 打赏
  • 举报
回复
顶个
fjtxwd 2009-07-28
  • 打赏
  • 举报
回复
用非绑定的方式写吧
love_cloud 2009-07-28
  • 打赏
  • 举报
回复
1 行专列
2 换控件
回答完毕
laoban108 2009-07-28
  • 打赏
  • 举报
回复
行列装换
cszg_zjy 2009-07-28
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 libinguest 的回复:]
DataTable old_dt = "从数据库得到的表";
            DataTable new_dt = "转换后的表";
            DataColumn dc_Columns = new DataColumn("名称列");
            DataColumn dc_values = new DataColumn("值列");
            new_dt.Columns.Add(dc_Columns);
            new_dt.Columns.Add(dc_values);
            for (int count = 0; count < dt.Columns.Count; count++)
            {
                new_dt.Rows.Add(dt.Columns[count].ColumnName.ToString(),int.Parse(dt.Rows[0]["你数据库值的列名"].ToString()));
            }
            //dgv绑定新表
[/Quote]UP~~
shui8iuhs 2009-07-28
  • 打赏
  • 举报
回复
[Quote=引用 18 楼 hbxtlhx 的回复:]
可以都以字符串的方式来显示,使用cast(b as varchar(50))
select 'a', a from test where a=1
union
select 'b', cast(b as varchar(50)) from test where a=1
union
select 'c', c from test where a=1
[/Quote]

好的,我试试,谢谢各位。
北京的雾霾天 2009-07-28
  • 打赏
  • 举报
回复
可以都以字符串的方式来显示,使用cast(b as varchar(50))
select 'a', a from test where a=1
union
select 'b', cast(b as varchar(50)) from test where a=1
union
select 'c', c from test where a=1
北京的雾霾天 2009-07-28
  • 打赏
  • 举报
回复
可以都以字符串的方式来显示,使用cast(b as varchar(50)
xml120 2009-07-28
  • 打赏
  • 举报
回复
备注:大师分隔符
发布时间:2009-7-2 19:41:55
有效时间:2009-8-7 0:00:00


显示出来就这样格式了。
xml120 2009-07-28
  • 打赏
  • 举报
回复

<asp:TemplateField HeaderText="整船基本信息">
<ItemTemplate>
备注:<%#Eval("memo")%>
<br />
发布时间:<%#Eval("createTime")%><br />
有效时间:<%#Eval("effdate")%><br />
</ItemTemplate>
<ItemStyle Width="850px" />
</asp:TemplateField>
xml120 2009-07-28
  • 打赏
  • 举报
回复
用模板列啊。

直接在里面设置显示格式。

风之影子 2009-07-28
  • 打赏
  • 举报
回复
DataTable new_dt = "转换后的表";
上面错了,应该是:

DataTable New_dt=New DataTable()


加载更多回复(9)
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)

110,533

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧