111,097
社区成员




DbBuild dbbuild = new DbBuild();//实例化数据库操作对象
/// <summary>
/// 动态创建TreeView
/// </summary>
/// <param name="sqlText">传入的SQL语句</param>
/// <param name="nodes">TreeView节点集</param>
public void CreateTreeView(string sqlText, TreeNodeCollection nodes)
{
try
{
DataTable dbTable = new DataTable();//实例化一个DataTable数据表对象
dbTable = dbbuild.GetDbTable(sqlText);//返数据表
//将第一级菜单取出生成TreeView的节点,作为递归运算的入口递归查询出TreeView的所有节点数据
CreateTreeViewRecursive(nodes, dbTable, 0);
}
catch (Exception tv_ex)
{
MessageBox.Show(tv_ex.Message);
}
}
/// <summary>
/// 递归查询
/// </summary>
/// <param name="nodes">TreeView节点集合</param>
/// <param name="dataSource">数据源</param>
/// <param name="parentid">上一级菜单节点标识码</param>
public void CreateTreeViewRecursive(TreeNodeCollection nodes, DataTable dataSource, int parentid)
{
string filter;//定义一个过滤器
filter = string.Format("Menu_ParentId={0}", parentid);
DataRow[] drarr = dataSource.Select(filter);//将过滤的ID放入数组中
TreeNode node;
foreach (DataRow dr in drarr)//递归循环查询出数据
{
node = new TreeNode();
node.Text = dr["Menu_Name"].ToString();
node.Tag = Convert.ToInt32(dr["Menu_Id"]);
nodes.Add(node);//加入节点
CreateTreeViewRecursive(node.Nodes, dataSource, Convert.ToInt32(node.Tag));
}
}