2017-08-07 103 views
0

我試圖用SQL查詢填充DataGrid,然後能夠過濾數據網格。到目前爲止,我有這樣的:未填充綁定的DataGrid

XAML

<Window x:Name="ResultsWindow" x:Class="PixsellSheet.PixsellOrders" 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
    xmlns:local="clr-namespace:PixsellSheet" 
    mc:Ignorable="d" Height="721.175" Width="1549.21" Title="edit" WindowStartupLocation="CenterScreen"> 
<Grid> 
    <DataGrid x:Name="Grid" HorizontalAlignment="Stretch" Height="Auto" Margin="20,55,20,40" VerticalAlignment="Stretch" Width="Auto" ItemsSource="{Binding DataGridColletion}"> 
     <DataGrid.Resources> 
      <ContextMenu x:Key="DataGridColumnHeaderContextMenu"> 
       <MenuItem Header="Filter" Click="MenuItem_Click"/> 
      </ContextMenu> 
      <Style TargetType="{x:Type DataGridColumnHeader}"> 
       <Setter Property="ContextMenu" Value="{StaticResource DataGridColumnHeaderContextMenu}"/> 
      </Style> 
     </DataGrid.Resources> 
    </DataGrid> 
    <Button x:Name="BtnBack" HorizontalAlignment="Left" Margin="20,10,0,0" VerticalAlignment="Top" Width="30" Click="BtnBack_Click" Padding="20,0,5,0"> 
     <Button.Template> 
      <ControlTemplate TargetType="{x:Type Button}"> 
       <Grid> 
        <Image Name="Normal" Source="back.png"/> 
        <Image Name="Pressed" Source="back_pressed.png"/> 
       </Grid> 
       <ControlTemplate.Triggers> 
        <Trigger Property="IsPressed" Value="True"> 
         <Setter TargetName="Normal" Property="Visibility" Value="Hidden"/> 
         <Setter TargetName="Pressed" Property="Visibility" Value="Visible"/> 
        </Trigger> 
        <Trigger Property="IsPressed" Value="False"> 
         <Setter TargetName="Normal" Property="Visibility" Value="Visible"/> 
         <Setter TargetName="Pressed" Property="Visibility" Value="Hidden"/> 
        </Trigger> 
       </ControlTemplate.Triggers> 
      </ControlTemplate> 
     </Button.Template> 
    </Button> 
    <TextBox Height="27" Margin="0,10,20,0" TextWrapping="Wrap" VerticalAlignment="Top" HorizontalAlignment="Right" Width="524" Name="FilterBox" Padding="5,0,20,0"/> 
    <Label Content="Filter:" HorizontalAlignment="Right" Margin="0,10,550,0" VerticalAlignment="Top" Padding="5,0,5,0"/> 
    <Grid HorizontalAlignment="Left" Height="25" Margin="60,10,0,0" VerticalAlignment="Top" Width="20" /> 
</Grid> 

C#

public partial class PixsellOrders : Window, INotifyPropertyChanged 
{ 
    public ICollectionView _dataGridCollection; 
    private string _filterString; 

    public ICollectionView DataGridCollection 
    { 
     get { return _dataGridCollection; } 
     set { _dataGridCollection = value; NotifyPropertyChanged("DataGridCollection"); } 
    } 

    public PixsellOrders(string windowTitle) 
    { 
     InitializeComponent(); 

     string query = ""; 

     ResultsWindow.Title = windowTitle; 

     Console.WriteLine(windowTitle); 

     if (windowTitle == "PixSell Orders All") 
     { 
      query = "EXEC Reporting.dbo.Pixsell_Orders_All"; 
     } 
     else if (windowTitle == "PixSell Orders Eday") 
     { 
      query = "EXEC Reporting.dbo.Pixsell_Orders_Eday"; 
     } 

     Console.WriteLine(query); 

     try 
     { 
      DataTable pixsellOrders = SqlConnect(query); 

      foreach (DataColumn column in pixsellOrders.Columns) 
      { 
       column.ReadOnly = true; 

       if (column.ColumnName == "Person" && windowTitle != "PixSell Orders All") 
       { 
        pixsellOrders.Columns["Person"].ReadOnly = false; 
       } 
       else if (column.ColumnName == "Sales Notes" && windowTitle != "PixSell Orders All") 
       { 
        pixsellOrders.Columns["Sales Notes"].ReadOnly = false; 
       } 
      } 

      DataGridCollection = CollectionViewSource.GetDefaultView(pixsellOrders.AsEnumerable()); 
      DataGridCollection.Filter = new Predicate<object>(Filter); 

      pixsellOrders.ColumnChanged += new DataColumnChangeEventHandler(Column_Changed); 

     } 
     catch (SqlException sqlEr) 
     { 
      Console.WriteLine(sqlEr); 
     } 
    } 

    public event PropertyChangedEventHandler PropertyChanged; 

    private void NotifyPropertyChanged(string property) 
    { 
     if (PropertyChanged != null) 
     { 
      PropertyChanged(this, new PropertyChangedEventArgs(property)); 
      _dataGridCollection.Refresh(); 
     } 
    } 

    public DataTable SqlConnect(string query) 
    { 
     SqlConnection ohsql1; 
     string sqlQuery = query; 

     ohsql1 = new SqlConnection("Data Source=OHSQL1;Initial Catalog=Reporting;Integrated Security = true"); 


     DataTable table = new DataTable(); 

     try 
     { 
      //connect 
      ohsql1.Open(); 

      //fill datatable with results 
      SqlDataAdapter a = new SqlDataAdapter(sqlQuery, ohsql1); 

      //fill table 
      a.Fill(table); 

      //kill connection 
      a.Dispose(); 
      ohsql1.Close(); 

     } 
     catch (SqlException e) 
     { 
      Console.WriteLine("SQL ERROR: " + e); 
     } 

     return table; 
    } 

    private void MenuItem_Click(object sender, RoutedEventArgs e) 
    { 
     _filterString = FilterBox.Text; 

     if (_filterString == "") 
     { 
      Console.WriteLine("no filter"); 
      return; 
     } 
     else 
     { 
      Console.WriteLine(_filterString); 
      FilterCollection(); 
     } 
    } 

    private void FilterCollection() 
    { 
     if (_dataGridCollection != null) 
     { 
      _dataGridCollection.Refresh(); 
     } 
    } 

    private bool Filter(object obj) 
    { 
     if (obj is DataRow data) 
     { 
      if (!string.IsNullOrEmpty(_filterString)) 
      { 
       return data["CUNAME"].ToString().Contains(_filterString); 
      } 
      else 
      { 
       return true; 
      } 

     } 
     return false; 
    } 

規定的 「CUNAME」 列只是測試,最終我想擁有它知道哪些列過濾器按鈕被按下。

我得到的問題是DataGrid返回空。當我做Grid.ItemsSource = pixsellOrders.DefaultView(或者那種效果,不記得確切的語法),它工作正常,並填充網格。

我已經嘗試更改爲列表,肯定會IEnumerable但不是填充數據網格。添加AutoGenerateColumns(或爲true或false)不起作用。輸出中沒有顯示錯誤。註釋掉所有過濾器部件也沒有效果。刪除上下文菜單也不起作用。刪除AsEnumerable()對網格填充沒有影響,但在DataGridCollection.Filter上拋出並出錯。

任何人都可以看到哪裏出錯了?如果你可以告訴我怎麼可能去獲得列名檢查(而不是硬編碼的所有列),我們是真正有用的爲好)

預先感謝您

+0

被抓住了!但不幸的是不是這個問題(我拼錯了,當我嘗試沒有添加綁定後) – Jackimedes

回答

1

設置WindowDataContext本身:

public PixsellOrders(string windowTitle) 
{ 
    InitializeComponent(); 
    DataContext = this; 

    //... 
} 
+0

這絕對會增加我的網格!然而,AsEnumerable將廢話傳遞給網格,但刪除它會拋出「不支持指定的方法」 DataGridCollection.Filter = new謂詞(Filter); – Jackimedes

+0

不幸的是有同樣的錯誤 – Jackimedes

+0

如果您有新問題,請提出一個新問題。你原來的問題是關於綁定和空DataGrid。 – mm8