现在的位置: 首页 > 综合 > 正文

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

2013年11月03日 ⁄ 综合 ⁄ 共 2909字 ⁄ 字号 评论关闭
这几天总看到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);
    }

   }

  }

  
 
 }

}

 

抱歉!评论已关闭.