请教如梦,一个关联表数据在DataGridView的处理,谢谢!

捷哥1999 2010-11-27 10:39:26
班级表.班级编号
学生表.班级编号

我用
sqldataadapter.Fill(ds,"班级");
sqldataadapter.Fill(ds,"学生信息");

填充数据后,在ds中建立他们之间的关系:

ds.Relations.Add("每个班级的学生",ds.Tables["班级"].Columns["班级编号"],ds.Tables["学生信息"].Columns["班级编号"])


如果是用DataGrid的话,那么只要:
DataGrid1.SetDataBinding(ds,"班级.每个班级的学生")


就可以实现当班级表数据位置改变时,DataGrid控件中的学生信息数据,就跟着同步改变。
但是我用DataGridView控件了,没有SetDataBinding方法,要怎么弄呢?
...全文
136 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
q107770540 2010-11-28
  • 打赏
  • 举报
回复
解决就好
GSDN00A 2010-11-28
  • 打赏
  • 举报
回复
我不要,转非技术区,自己留着吧。

这种问题不要问。
GSDN00A 2010-11-28
  • 打赏
  • 举报
回复
我不要,转非技术区,自己留着吧。

这种问题不要问。
GSDN00A 2010-11-28
  • 打赏
  • 举报
回复
我不要,转非技术区,自己留着吧。

这种问题不要问。
捷哥1999 2010-11-28
  • 打赏
  • 举报
回复
虽然分数不多,哈。
捷哥1999 2010-11-28
  • 打赏
  • 举报
回复
各位回帖,我送分了。
捷哥1999 2010-11-28
  • 打赏
  • 举报
回复
呵呵,在Ado.net要用两个BindingSource来搞定!
代码大致如下:

SqlConnection conn = new SqlConnection();
SqlConnectionStringBuilder ssb = new SqlConnectionStringBuilder();
conn.ConnectionString =
"Data Source=localhost; Initial Catalog=Northwind; Integrated Security = True;";
conn.Open();

DataSet dbSet = new DataSet(); // 创建数据集
using (SqlDataAdapter da = new SqlDataAdapter("select * from Customers", conn))
{
da.Fill(dbSet, "Customers"); // 填充一个 Customers 表
}
using (SqlDataAdapter da = new SqlDataAdapter("select * from Orders", conn))
{
da.Fill(dbSet, "Orders"); // 填充一个 Orders 表
}

DataColumn parentCol = dbSet.Tables["Customers"].Columns["CustomerID"];
DataColumn childCol = dbSet.Tables["Orders"].Columns["CustomerID"];
DataRelation relation =
new DataRelation("FK_Customers_Orders", parentCol, childCol); // 建立主从关系
dbSet.Relations.Add(relation); // 添加主从关系到数据集中

BindingSource bs_Customers = new BindingSource(); // 创建绑定源
BindingSource bs_Orders = new BindingSource();

bs_Customers.DataSource = dbSet;
bs_Customers.DataMember = "Customers"; // 绑定到数据源——主表

bs_Orders.DataSource = bs_Customers;
bs_Orders.DataMember = "FK_Customers_Orders"; // 绑定到关系——从表,注意:区分大小写

dataGridView1.DataSource = bs_Customers; // DataGridView 显示
dataGridView2.DataSource = bs_Orders;


参考自:http://www.cnblogs.com/top5/archive/2009/08/23/1552459.html

110,539

社区成员

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

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

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