ASP.NET中treeview与数据库绑定的方法与相关源码

这几天总看到CSDN上有人问到treeview与数据库的绑定问题,刚好这几天也做了个这东西。网上也有讲treeview的文章,可是搜来搜去就那一篇,而且是与access关联的。
下面讲一下实现方法。以下是实现效果。

第一步:VS的WEB开发是没有treeview这个控件的,所以首先要到微软网站( http://msdn.microsoft.com/downloads/samples/internet/ASP_DOT_NET_ServerControls/
WebControls/default.asp)上去把控件下下来,网站上有具体的安装方法,只有安装完成才能用此控件。
第二步:数据库设计
直接看截图。下面是数据库的设计。

下面是数据库里面的值。

以下是代码,主要用递归的算法来实现对treeview的node的添加。
using  System;
using  System.Collections;
using  System.ComponentModel;
using  System.Data;
using  System.Drawing;
using  System.Web;
using  System.Web.SessionState;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.HtmlControls;
using  Microsoft.Web.UI.WebControls;
using  System.Data.SqlClient;
using  System.Configuration; 
namespace  TestOnline.treeView
{
 
/// <summary>
 
/// treeView1 的摘要说明。
 
/// </summary>

 public class treeView1 : System.Web.UI.Page
 
{
  
protected System.Web.UI.WebControls.DataGrid DataGrid1;
  
protected System.Web.UI.WebControls.TextBox TextBox1;
  
protected System.Web.UI.WebControls.CheckBox CheckBox1;
  
protected System.Web.UI.WebControls.Button Button1;
  
protected Microsoft.Web.UI.WebControls.TreeView TreeView3;
  
public static string url="workstation id=All;packet size=4096;UID=sa;password=;data source=(local);persist security info=True;initial catalog=TestOnline;Max Pool Size=500;Min Pool Size=5";
  
public SqlConnection myConnection=new SqlConnection(url);
  
private void Page_Load(object sender, System.EventArgs e)
  
{
   
// 在此处放置用户代码以初始化页面
   
   
try
   
{
   
    myConnection.Open();
    SqlDataAdapter sda
=new SqlDataAdapter("select * from tbTree",myConnection);
    DataSet ds
=new DataSet();
    sda.Fill(ds);
    
this.ViewState["ds"]=ds;
   }

   
catch(Exception ex)
   
{
    Console.Write(ex);
    Response.Redirect(
"login.aspx");
   }

   
finally
   
{
       myConnection.Close();
   }

   AddTree(
"0", (TreeNode)null);
      
  }

  
Web 窗体设计器生成的代码
  
public void AddTree(string id,TreeNode pNode)
  
{
   DataSet ds
=(DataSet)this.ViewState["ds"];
   DataView dv
=new DataView(ds.Tables[0]);
   dv.RowFilter
="parentId = '"+id +"'";
   
foreach(DataRowView row in dv)
   
{
    TreeNode node
=new TreeNode();
    
if(pNode==null)
     
//说明是根节点
    {
     node.Text
=row["content"].ToString();
     TreeView3.Nodes.Add(node);
     node.Expanded
=true;
     
//AddTree(Int32.Parse(row["ID"].ToString()),node);
    AddTree(row["ID"].ToString(),node);
    }

    
else
    
{
     node.Text
=row["content"].ToString();
     pNode.Nodes.Add(node);
     node.Expanded
=true;
     
//AddTree(Int32.Parse(row["ID"].ToString()),node);
     AddTree(row["ID"].ToString(),node);
    }

   }

  }

  
 
 }

}
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值