将TreeView绑定到DataSet

时间:2012-12-23 13:33:05

标签: wpf data-binding treeview dataset

我有一个从Oracle Query创建的数据集。 我从函数中获取数据表并将其添加到数据集中。

现在我尝试将树视图绑定到ds。 我的代码背后:

private void init_TreeView()
        { 

           //TreeViewItem parent = PM_TreeView.Items.Add("Requirements");
           DataTable dt  =  DataBases.RunQuery();
           dt.TableName = "REQ";
           DataSet ds = new DataSet();
           ds.Tables.Add(dt);
           //ds.Relations.Add("rsParentChild", ds.Tables["REQ"].Columns["RQ_REQ_ID"], ds.Tables["REQ"].Columns["RQ_FATHER_ID"]);
           var dataSet = ds;
           _rootNodes = dataSet.Tables["REQ"].DefaultView;
           _rootNodes.RowFilter = "RQ_FATHER_ID = -1";
           this.DataContext = this;
         }

private DataView _rootNodes;

public DataView RootNodes
{
    get { return _rootNodes; }
}

和我的XAML:

<TreeView x:Name="PM_TreeView" ItemsSource="{Binding RootNodes}" HorizontalAlignment="Left" Height="445" Margin="44.847,68.285,0,0" VerticalAlignment="Top" Width="320" Foreground="{x:Null}" BorderBrush="{x:Null}" Background="#FFBBB6B6" FontFamily="Segoe UI" FontSize="13.333">
            <TreeView.ItemTemplate>
                <HierarchicalDataTemplate ItemsSource="{Binding rsParentChild}">
                    <TextBlock Text="{Binding NodeDescription}" />
                </HierarchicalDataTemplate>
            </TreeView.ItemTemplate>
        </TreeView>

我的数据表是:

RQ_REQ_ID RQ_FATHER_ID RQ_REQ_NAME
0         -1           REQ
1          0           QC11

但我对树视图一无所知:)

提前10倍。

1 个答案:

答案 0 :(得分:1)

我尝试了以下内容:

    <TreeView Name="tv" ItemsSource="{Binding Root}">
        <TreeView.ItemTemplate>
            <HierarchicalDataTemplate ItemsSource="{Binding Parents}">
                <TextBlock Text="{Binding Value}"/>
            </HierarchicalDataTemplate>
        </TreeView.ItemTemplate>
    </TreeView>

在我的窗口中我有:

        DataSet ds = new DataSet("Data");

        DataTable t = new DataTable("Table");
        t.PrimaryKey = new DataColumn[] { t.Columns.Add("Key", typeof(int)) };
        t.Columns.Add("Value", typeof(string));
        t.Columns.Add("Father", typeof(int));
        ds.Tables.Add(t);

        ds.Relations.Add("Parents", t.Columns["Key"], t.Columns["Father"], false);

        t.Rows.Add(1, "First", -1);
        t.Rows.Add(2, "Second", -1);
        t.Rows.Add(3, "Third", 2);

        Root = new DataView(t);
        Root.RowFilter = "[Father]<0";
        t.DefaultView.RowFilter = "[Father] < 0";

        tv.DataContext = this;

其中Root被声明为:

public DataView Root { get; private set; }

结果与预期一致。