none
求教:datagrid可以显示单个datatable,但无法显示dataset中多个表 RRS feed

  • 问题

  • 服务器端webservice函数查询数据库,返回dataset(含有多个datatable)

    客户端接收dataset并通过datagrid显示

    但只显示一个datatable的表名链接,点击后无法打开相应datatable

    如果将datagrid.datasource改成其中任一个datatable,却可以正常显示

    在服务器端查询webservice生成的xml网页,发现查询的数据库中框架和数据都正常读出

    在google搜索了一下

    有些类似问题说用datagrid.DataBind()就可以

    但我没有找到这个属性 只有databindings(),而且没有作用

    求教各位

    谢谢!

     


    2008年12月22日 8:48

答案

  • Code Snippet

    表间设置就关系就可以显示多个。完整示例代码


    System.Data.DataSet ds = new System.Data.DataSet();
    System.Data.DataTable dataTable1 = new System.Data.DataTable("BlogUser");
    System.Data.DataRow dr;
    dataTable1.Columns.Add(new System.Data.DataColumn("UserId", typeof(System.Int32)));
    dataTable1.Columns.Add(new System.Data.DataColumn("UserName", typeof(System.String)));
    dataTable1.PrimaryKey = new System.Data.DataColumn[] { dataTable1.Columns["UserId"] };

    for (int i = 0; i < 8; i++)
    {
    dr = dataTable1.NewRow();
    dr[0] = i;
    dr[1] = "【孟子E章】" + i.ToString();
    dataTable1.Rows.Add(dr);
    }

    System.Data.DataTable dataTable2 = new System.Data.DataTable("BlogArticle");
    dataTable2.Columns.Add(new System.Data.DataColumn("ArticleId", typeof(System.Int32)));
    dataTable2.Columns.Add(new System.Data.DataColumn("Title", typeof(System.String)));
    dataTable2.Columns.Add(new System.Data.DataColumn("UserId", typeof(System.Int32)));
    dataTable2.PrimaryKey = new System.Data.DataColumn[] { dataTable1.Columns["ArticleId"] };
    Random rd = new Random();
    for (int i = 0; i < 8; i++)
    {
    dr = dataTable2.NewRow();
    dr[0] = i;
    dr[1] = "文章标题" + i.ToString();
    dr[2] = rd.Next(0, 7);
    dataTable2.Rows.Add(dr);
    }
    ds.Tables.Add(dataTable1);
    ds.Tables.Add(dataTable2);

    System.Data.DataColumn parentColumn = ds.Tables["BlogUser"].Columns["UserId"];
    System.Data.DataColumn childColumn = ds.Tables["BlogArticle"].Columns["UserId"];
    System.Data.DataRelation user_article = new System.Data.DataRelation("UserId", parentColumn, childColumn);
    ds.Relations.Add(user_article);

    DataGrid dg = new DataGrid();
    dg.Location = new Point(0, 100);
    dg.Width = 600;
    dg.Height = 400;
    dg.DataSource = ds;
    //dg.DataMember = "BlogArticle";
    this.Controls.Add(dg);





    2008年12月22日 9:45
    版主

全部回复

  • Code Snippet

    表间设置就关系就可以显示多个。完整示例代码


    System.Data.DataSet ds = new System.Data.DataSet();
    System.Data.DataTable dataTable1 = new System.Data.DataTable("BlogUser");
    System.Data.DataRow dr;
    dataTable1.Columns.Add(new System.Data.DataColumn("UserId", typeof(System.Int32)));
    dataTable1.Columns.Add(new System.Data.DataColumn("UserName", typeof(System.String)));
    dataTable1.PrimaryKey = new System.Data.DataColumn[] { dataTable1.Columns["UserId"] };

    for (int i = 0; i < 8; i++)
    {
    dr = dataTable1.NewRow();
    dr[0] = i;
    dr[1] = "【孟子E章】" + i.ToString();
    dataTable1.Rows.Add(dr);
    }

    System.Data.DataTable dataTable2 = new System.Data.DataTable("BlogArticle");
    dataTable2.Columns.Add(new System.Data.DataColumn("ArticleId", typeof(System.Int32)));
    dataTable2.Columns.Add(new System.Data.DataColumn("Title", typeof(System.String)));
    dataTable2.Columns.Add(new System.Data.DataColumn("UserId", typeof(System.Int32)));
    dataTable2.PrimaryKey = new System.Data.DataColumn[] { dataTable1.Columns["ArticleId"] };
    Random rd = new Random();
    for (int i = 0; i < 8; i++)
    {
    dr = dataTable2.NewRow();
    dr[0] = i;
    dr[1] = "文章标题" + i.ToString();
    dr[2] = rd.Next(0, 7);
    dataTable2.Rows.Add(dr);
    }
    ds.Tables.Add(dataTable1);
    ds.Tables.Add(dataTable2);

    System.Data.DataColumn parentColumn = ds.Tables["BlogUser"].Columns["UserId"];
    System.Data.DataColumn childColumn = ds.Tables["BlogArticle"].Columns["UserId"];
    System.Data.DataRelation user_article = new System.Data.DataRelation("UserId", parentColumn, childColumn);
    ds.Relations.Add(user_article);

    DataGrid dg = new DataGrid();
    dg.Location = new Point(0, 100);
    dg.Width = 600;
    dg.Height = 400;
    dg.DataSource = ds;
    //dg.DataMember = "BlogArticle";
    this.Controls.Add(dg);





    2008年12月22日 9:45
    版主
  • 至少两个表之间要有一些关系吧,就向SQL查询一样。。

     

    2008年12月23日 12:42
    版主