C# TreeView从数据库绑定数据
2017-08-15 16:27
411 查看
封装成一个函数,方便直接调用
//绑定TrreView
private void InitModuleTree(DataTable dt)
{
//清空treeview上所有节点
this.tree_Role.Nodes.Clear();
int[] gen = new int[dt.Rows.Count]; //用于存储父节点Tag
int[] zi = new int[dt.Rows.Count]; //用于存储子节点Tag
for (int i = 0; i < gen.Length; i++)
{
string zhi=dt.Rows[i][3].ToString();//获取节点Tag值 eg:1-2
if (zhi.Length>1) //表示是子节点 eg:1-2
{
gen[i] = int.Parse(zhi.Substring(0, zhi.IndexOf('-')));
zi[i] = int.Parse(zhi.Substring(zhi.IndexOf('-') + 1));
}
else //表示是根节点 eg:2
{
//将所有父节点加到treeview上
zi[i] =int.Parse(zhi);
TreeNode nodeParent = new TreeNode();
nodeParent.Tag = (zi[i]).ToString();
nodeParent.Text = dt.Rows[i][1].ToString();
tree_Role.Nodes.Add(nodeParent);
}
}
bindChildNote(dt,gen,zi);
}
数据库结构:
最终结果:
引用代码:
namespace TreeeeeeeeeeeView
{
public partial class Treeeeeeeeeee : Form
{
public Treeeeeeeeeee()
{
InitializeComponent();
//从数据库获取数据,得到结果为DataTable
SystemManager.Dao.RolePower dao = new SystemManager.Dao.RolePower();
DataSet ds = CommonLib.Dao.CompressUtil.DeCompress(dao.getSystemModule());
DataTable dt = ds.Tables[0];
InitModuleTree(dt);
}
//绑定TrreView
private void InitModuleTree(DataTable dt)
{
//清空treeview上所有节点
this.tree_Role.Nodes.Clear();
int[] gen = new int[dt.Rows.Count]; //用于存储父节点Tag
int[] zi = new int[dt.Rows.Count]; //用于存储子节点Tag
for (int i = 0; i < gen.Length; i++)
{
string zhi=dt.Rows[i][3].ToString();//获取节点Tag值 eg:1-2
if (zhi.Length>1) //表示是子节点 eg:1-2
{
gen[i] = int.Parse(zhi.Substring(0, zhi.IndexOf('-')));
zi[i] = int.Parse(zhi.Substring(zhi.IndexOf('-') + 1));
}
else //表示是根节点 eg:2
{
//将所有父节点加到treeview上
zi[i] =int.Parse(zhi);
TreeNode nodeParent = new TreeNode();
nodeParent.Tag = (zi[i]).ToString();
nodeParent.Text = dt.Rows[i][1].ToString();
tree_Role.Nodes.Add(nodeParent);
}
}
bindChildNote(dt,gen,zi);
}
//绑定子节点 private void bindChildNote(DataTable dt, int[] gen, int[] zi) { for (int i = 0; i < gen.Length; i++) { if (gen[i] != 0 && zi[i] != 0) //便利所有节点,找到所有子节点 { TreeNode childNode = new TreeNode(); foreach (TreeNode item in tree_Role.Nodes) //便历treeview上所有父节点 { if (item.Tag.ToString() == gen[i].ToString()) //找到当前子节点的父节点 { childNode.Tag = zi[i].ToString(); childNode.Text = dt.Rows[i][1].ToString(); item.Nodes.Add(childNode); } } } } tree_Role.ExpandAll(); //展开整棵树 }
}
}
//绑定TrreView
private void InitModuleTree(DataTable dt)
{
//清空treeview上所有节点
this.tree_Role.Nodes.Clear();
int[] gen = new int[dt.Rows.Count]; //用于存储父节点Tag
int[] zi = new int[dt.Rows.Count]; //用于存储子节点Tag
for (int i = 0; i < gen.Length; i++)
{
string zhi=dt.Rows[i][3].ToString();//获取节点Tag值 eg:1-2
if (zhi.Length>1) //表示是子节点 eg:1-2
{
gen[i] = int.Parse(zhi.Substring(0, zhi.IndexOf('-')));
zi[i] = int.Parse(zhi.Substring(zhi.IndexOf('-') + 1));
}
else //表示是根节点 eg:2
{
//将所有父节点加到treeview上
zi[i] =int.Parse(zhi);
TreeNode nodeParent = new TreeNode();
nodeParent.Tag = (zi[i]).ToString();
nodeParent.Text = dt.Rows[i][1].ToString();
tree_Role.Nodes.Add(nodeParent);
}
}
bindChildNote(dt,gen,zi);
}
//绑定子节点 private void bindChildNote(DataTable dt, int[] gen, int[] zi) { for (int i = 0; i < gen.Length; i++) { if (gen[i] != 0 && zi[i] != 0) //便利所有节点,找到所有子节点 { TreeNode childNode = new TreeNode(); foreach (TreeNode item in tree_Role.Nodes) //便历treeview上所有父节点 { if (item.Tag.ToString() == gen[i].ToString()) //找到当前子节点的父节点 { childNode.Tag = zi[i].ToString(); childNode.Text = dt.Rows[i][1].ToString(); item.Nodes.Add(childNode); } } } } tree_Role.ExpandAll(); //展开整棵树 }
数据库结构:
最终结果:
引用代码:
namespace TreeeeeeeeeeeView
{
public partial class Treeeeeeeeeee : Form
{
public Treeeeeeeeeee()
{
InitializeComponent();
//从数据库获取数据,得到结果为DataTable
SystemManager.Dao.RolePower dao = new SystemManager.Dao.RolePower();
DataSet ds = CommonLib.Dao.CompressUtil.DeCompress(dao.getSystemModule());
DataTable dt = ds.Tables[0];
InitModuleTree(dt);
}
//绑定TrreView
private void InitModuleTree(DataTable dt)
{
//清空treeview上所有节点
this.tree_Role.Nodes.Clear();
int[] gen = new int[dt.Rows.Count]; //用于存储父节点Tag
int[] zi = new int[dt.Rows.Count]; //用于存储子节点Tag
for (int i = 0; i < gen.Length; i++)
{
string zhi=dt.Rows[i][3].ToString();//获取节点Tag值 eg:1-2
if (zhi.Length>1) //表示是子节点 eg:1-2
{
gen[i] = int.Parse(zhi.Substring(0, zhi.IndexOf('-')));
zi[i] = int.Parse(zhi.Substring(zhi.IndexOf('-') + 1));
}
else //表示是根节点 eg:2
{
//将所有父节点加到treeview上
zi[i] =int.Parse(zhi);
TreeNode nodeParent = new TreeNode();
nodeParent.Tag = (zi[i]).ToString();
nodeParent.Text = dt.Rows[i][1].ToString();
tree_Role.Nodes.Add(nodeParent);
}
}
bindChildNote(dt,gen,zi);
}
//绑定子节点 private void bindChildNote(DataTable dt, int[] gen, int[] zi) { for (int i = 0; i < gen.Length; i++) { if (gen[i] != 0 && zi[i] != 0) //便利所有节点,找到所有子节点 { TreeNode childNode = new TreeNode(); foreach (TreeNode item in tree_Role.Nodes) //便历treeview上所有父节点 { if (item.Tag.ToString() == gen[i].ToString()) //找到当前子节点的父节点 { childNode.Tag = zi[i].ToString(); childNode.Text = dt.Rows[i][1].ToString(); item.Nodes.Add(childNode); } } } } tree_Role.ExpandAll(); //展开整棵树 }
}
}
相关文章推荐
- C#里的treeview控件如何能绑定数据库里的数据
- c# 如何向comboBox中绑定数据库中指定的数据信息;
- 关于如何递归给TreeView从数据库中循环绑定数据
- TreeView从数据库绑定数据
- [转]C#反射,根据反射将数据库查询数据和实体类绑定,并未实体类赋值
- TreeView绑定数据库数据
- C# - 反射学习,附带绑定实体类从数据库查询数据中,带源码学习!
- C# 递归的应用 TreeView递归绑定数据
- asp.net2.0 treeview的用法--绑定数据库数据
- DX控件中TreeView绑定层次数据库数据
- Visual C# 2008+SQL Server 2005 数据库与网络开发-- 8.1 数据绑定
- c# 在datagridview中添加comboboxcolumn 绑定数据库读取显示数据
- C# 递归的应用 TreeView递归绑定数据
- c# comboBox与数据库中的数据绑定
- C# 里TreeView绑定数据库实现分类
- C# 递归的应用 TreeView递归绑定数据
- C#动态从数据库中取值绑定TreeView节点
- C# 里TreeView绑定数据库实现分类
- [转]C#反射,根据反射将数据库查询数据和实体类绑定,并未实体类赋值