首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > asp.net >

DataGrid绑定多个表数据有关问题

2012-03-11 
DataGrid绑定多个表数据问题三个表1:user用户表字段比如有:ID,Name,department,role2:Department部门表字

DataGrid绑定多个表数据问题
三个表
1:user用户表
字段比如有:ID,Name,department,role
2:Department部门表
字段有:ID,name
3:Role角色表
字段有:ID,name

如何查询把用户的姓名,所属部门,角色查询并显示到DataGrid上面
要求查询出来的值由DataTable做数据源绑定到DataGrid上面,请问怎么解决

紧急!谢谢大虾们!!!

如建临时表请问怎么处理,小弟不是很熟悉,如果建试图又是如何去解决的?

麻烦高手赐教!

[解决办法]



1. string s= "select a.*,b.*,c* from user a,Department b,Role c where a.department=b.ID and a.role=c.ID "

2.DataGrid1.DataSource=//执行sql语句返回来的DataTable
DataGrid1.DataBind();


[解决办法]
这种情况,做成视图比较通用一点.
create view view_test
as
select a.*,b.*,c* from user a join Department b on a.department=b.id
join role c on a.role=c.id
[解决办法]
在数据库上做一个包含表1、2、3各需要字段的视图,应该easy,楼上正解。
[解决办法]
如果是要这三个表的内容用一条查询语句就可以满足
生成视图也可以但是不方便以后的变动
如果你不怕麻烦 还可以分别查询3个表然后组合datatable
再对datagridbind
[解决办法]
有两套方案:
一、在SQL查询语句中使用连接(假如楼主你只关心结果)
select a.ID,a.Name,a.department,a.role,
b.ID,b.name,c.ID,c.name
from 用户表 a,部门表 b,角色表 c
where a.department=b.ID and a.role=c.ID
这样直接连接的好处就是简单,但假如楼主你查询的数据条目数不多完全可以考虑这样做,这样做的坏处就是性能低下,数据库中实体关系结构散乱。
二、建立表与表之间的关系,然后创建视图
关系草图: 部门表 《- 用户表 《- 角色表
有了正确的关系后创建视图便比较简单,但要注意一点的是视图当中表与表的连接是左连接、右连接还是内连。
这样做的好处就是解决方案一的坏处,这样做的坏处刚好破坏了方案一的好处。
[解决办法]
只有三个表,直接查询就好了,不是很麻烦
[解决办法]
三个表建立试图view,直接用datagrid绑定试图view就可以
[解决办法]
user用户表和Role角色表是一对一关系的,那就用简单的视图或者直接拼SQL语句读取。如果是一对多关系,可以用DataGrid嵌套或者写条复杂点的SQL语句了。
[解决办法]
自己写一个object datasource啦
[解决办法]
一條sql就能解決的問題,搞那麼複雜,大項目????
[解决办法]
1. string s= "select a.*,b.*,c* from user a,Department b,Role c where a.department=b.ID and a.role=c.ID "

2.DataGrid1.DataSource=//执行sql语句返回来的DataTable
DataGrid1.DataBind();
[解决办法]
前面的我就不写了
da.fill(dt, "表1,表2,表3,表4 ")
DataGrid1.DataSource=dt;
DataGrid1.DataBind();

热点排行