Wie man Baumansicht mit Dateipfad füllt, der in der Datenbank gespeichert wird
Angenommen, ich habe den Dateipfad in der Datenbank gespeichert. jetzt möchte ich diesen Dateipfad durch treeview zeigen. Ich fand eine Probe, die gut funktioniert, aber nicht weiß, wann es riesige Daten in der Datenbank geben wird, dann wird die Baumansicht-Population hängen bleiben oder zu lange dauern. Hier gebe ich den Code. Bitte überprüfen Sie und sagen Sie, was korrigiert werden kann, da die Leistung bei großen Datenmengen in db gut sein wird.
public static class MyDataBase
{
private static List<string> fields = new List<string>();
public static void AddField(string field)
{
fields.Add(field);
}
public static IList<string> FieldsInMyColumn()
{
return fields;
}
}
public void CreateTreeView()
{
foreach (string field in MyDataBase.FieldsInMyColumn())
{
string[] elements = field.Split('\\');
TreeNode parentNode = null;
for (int i = 0; i < elements.Length - 1; ++i)
{
if (parentNode == null)
{
bool exits = false;
foreach (TreeNode node in myTreeview.Nodes)
{
if (node.Text == elements[i])
{
exits = true;
parentNode = node;
}
}
if (!exits)
{
TreeNode childNode = new TreeNode(elements[i]);
myTreeview.Nodes.Add(childNode);
parentNode = childNode;
}
}
else
{
bool exits = false;
foreach (TreeNode node in parentNode.Nodes)
{
if (node.Text == elements[i])
{
exits = true;
parentNode = node;
}
}
if (!exits)
{
TreeNode childNode = new TreeNode(elements[i]);
parentNode.Nodes.Add(childNode);
parentNode = childNode;
}
}
}
if (parentNode != null)
{
parentNode.Nodes.Add(elements[elements.Length - 1]);
}
}
}
private void button1_Click(object sender, EventArgs e)
{
MyDataBase.AddField(@"c:\jsmith\project1\hello.cs");
MyDataBase.AddField(@"c:\jsmith\project1\what.cs");
MyDataBase.AddField(@"c:\jsmith\project2\hello.cs");
MyDataBase.AddField(@"c:\jsmith\project1\tdp.cs");
MyDataBase.AddField(@"c:\jsmith\project2\ship.cs");
MyDataBase.AddField(@"d:\jsmith\project1\hello404.cs");
MyDataBase.AddField(@"c:\jsmith1\project2\ship.cs");
CreateTreeView();
}
Vielen Dank