多表DATASET的显示方法,自己乱搞的.

简介: 效果:表现层:Classlist.ascx       protected void Page_Load(object sender, EventArgs e)    {        dataclass datacls = (dataclass)Application["data"];        System.
效果:
{030A7B52-98FE-4378-A41D-6578B5532DF3}.JPG
表现层:
Classlist.ascx
<% @ Control Language = " C# "  ClassName = " classlist "   Debug = " true "   %>

< script runat = " server " >
   
    
protected   void  Page_Load( object  sender, EventArgs e)
    
{
        dataclass datacls 
= (dataclass)Application["data"];

        System.Data.DataSet ds 
= new System.Data.DataSet();
        ds
=datacls.getclasslist();
       
        
      
if (ds.Tables[0].Rows.Count > 0)
        
{
            
for (int i = 0; i <ds.Tables.Count; i++)
            
{
                PlaceHolder tt 
= new PlaceHolder();
                Label title 
= new Label();
               title.Text 
= ds.Tables[i].TableName;
                title.Font.Bold 
= true;
               tt.Controls.Add(title); 
                   
                DataList dl
=new DataList();
                dl.ItemTemplate 
= Page.LoadTemplate("/conterl/classitem.ascx");
                dl.RepeatDirection
=(RepeatDirection)0;
                dl.RepeatColumns 
= 4;
                dl.DataSource 
= ds.Tables[i];
                dl.DataBind();
                tt.Controls.Add(dl);
                PlaceHolder1.Controls.Add(tt);
            }

          
        }

       
       
    }

</ script >
< div id = " le_biaoti02 "   class = " left_biaoti " >
      
< img src = " ../image/bioti_02.gif "  width = " 60 "  height = " 26 "   />     
      
</ div >
       
< div id = " left_fenlei02 "   class = " left_fenlei "  runat = " server "   >
            
< asp:PlaceHolder ID = " PlaceHolder1 "  runat = " server " >
           
            
</ asp:PlaceHolder >
       
</ div >
/conterl/classitem.ascx
<% @ Control Language = " VB "    %>
 
<% # DataBinder.Eval(CType(Container, DataListItem).DataItem,  " error " %>
 
& nbsp; < a href = " class.aspx?id=<%# DataBinder.Eval(CType(Container, DataListItem).DataItem,  " ID " ) %> " >   <% #DataBinder.Eval(CType(Container, DataListItem).DataItem,  " classname " ) %></ a >< br  />

逻辑层:
///<summary>
    
/// 取得分类列表
    
/// </summary>

    public  DataSet getclasslist() 
   
{
        
try
        
{
            
string sqlstr = "";
            sqlstr 
= "select id,classname from classname where upid=0";
           DataSet dc
=new DataSet();
            dc
=getds(sqlstr);
            
            
if (dc.Tables[0].Rows.Count > 0)
            
{
                DataSet dl
=new DataSet();

                
for(int j=0;j<dc.Tables[0].Rows.Count;j++)
                
{
                sqlstr 
= "select top 3 id,classname from classname where upid=" + (int)dc.Tables[0].Rows[j]["id"];
                
                    dl
= getdsname(sqlstr, (string)dc.Tables[0].Rows[j]["classname"],dl);
                
                    dl.Tables[(
string)dc.Tables[0].Rows[j]["classname"]].Columns.Add("error");
                    DataRow drow;
                    drow 
= dl.Tables[(string)dc.Tables[0].Rows[j]["classname"]].NewRow();
                    drow[
"id"= (int)dc.Tables[0].Rows[j]["id"];
                    drow[
"classname"= "";
                    dl.Tables[(
string)dc.Tables[0].Rows[j]["classname"]].Rows.Add(drow);
                    
                }

       
                
return dl;
            }

            
else
            
{                
                
throw new Exception("no");
            }

        }

        
catch ( Exception ex)
        
{
            DataSet temp 
= new DataSet();
            DataTable dtServer 
= new DataTable();
            DataColumn dterror 
= new DataColumn("error");
            dterror.DataType 
= typeof(string);
            dtServer.Columns.Add(dterror);
            dtServer.Columns.Add(
"id"typeof(int));
            dtServer.Columns.Add(
"classname");
            DataRow drowServer;
            drowServer 
= dtServer.NewRow();
            drowServer[
"error"= ex.Message;
            dtServer.Rows.Add(drowServer);
            temp.Tables.Add(dtServer);
            
return temp;
        }

   }
数据层:
///<summary>
    
///返回Dataset类型的方法
    
///</summary>

     public  DataSet getds( string  sql)
    
{
        SqlCommand comm 
= new SqlCommand(sql, sqlconn);
        SqlDataAdapter da 
= new SqlDataAdapter(comm);
        DataSet temp 
= new DataSet();
        
int i=da.Fill(temp);
        
return temp;
     }

     
///<summary>
     
///返回Dataset类型的方法,带表名,添加新表
     
///</summary>

      public  DataSet getdsname( string  sql, string  name,DataSet ds)
     
{
         SqlCommand comm 
= new SqlCommand(sql, sqlconn);
         SqlDataAdapter da 
= new SqlDataAdapter(comm);
         
//DataSet temp = new DataSet();
         int i = da.Fill(ds,name);
         
return ds;
     }
以前没有做过这方面的东东,C#也是刚刚才开始用.今天用了一上午,终于做出来了,但这并不是真正的显示DATASET多个表的方法.
有没有人能告诉我方便快捷的方法呢?
相关文章
EXCEL导入程序中(针对excel单元格合并等导致的一行多条数据重复解决办法)
EXCEL导入程序中(针对excel单元格合并等导致的一行多条数据重复解决办法)
154 0
|
Web App开发 Python
直接保存“DataFrame表格”到本地,这个“骚操作”90%以上的人不知道!
直接保存“DataFrame表格”到本地,这个“骚操作”90%以上的人不知道!
直接保存“DataFrame表格”到本地,这个“骚操作”90%以上的人不知道!
分页列表数据不出来,初始化页面数据不出来的原因,Create中传一个参数1,解决bug的方法,学习敲代码的时候仔细与原项目比对,从上比到下
分页列表数据不出来,初始化页面数据不出来的原因,Create中传一个参数1,解决bug的方法,学习敲代码的时候仔细与原项目比对,从上比到下
|
8月前
|
SQL 关系型数据库 MySQL
简简单单 My SQL 学习笔记(1)——表中数据的整删改查
简简单单 My SQL 学习笔记(1)——表中数据的整删改查
|
8月前
【word】论文、报告:①插入图表题注,交叉引用②快速插入图表目录③删改后一键更新
【word】论文、报告:①插入图表题注,交叉引用②快速插入图表目录③删改后一键更新
872 0
|
数据库
【解决方案 二十五】如何对Excel表数据进行彻底转置
【解决方案 二十五】如何对Excel表数据进行彻底转置
113 0
|
SQL 数据挖掘 数据库
DataFrame多表合并拼接函数concat、merge参数详解+代码操作展示
DataFrame多表合并拼接函数concat、merge参数详解+代码操作展示
882 0
DataFrame多表合并拼接函数concat、merge参数详解+代码操作展示
|
关系型数据库 MySQL 数据库
MySQL数据库:第十一章:合并查询(联合查询)
MySQL数据库:第十一章:合并查询(联合查询)
106 0
|
SQL 存储 关系型数据库
纳尼,mysqldump导出的数据居然少了40万?(1)
纳尼,mysqldump导出的数据居然少了40万?
195 0
纳尼,mysqldump导出的数据居然少了40万?(1)
|
SQL 关系型数据库 MySQL
mysql索引_效率测试(包含测试sql脚本300万条数据),可用作教学案例。
mysql索引_效率测试(包含测试sql脚本300万条数据),可用作教学案例。
326 0
mysql索引_效率测试(包含测试sql脚本300万条数据),可用作教学案例。