Oracle クエリから作成したデータセットがあります。関数からデータテーブルを取得し、データセットに追加します。
今、ツリービューを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倍前。