2016-06-16 19 views
0

私のデータベースをコンボボックス( "ProjectComboBox")にバインドしようとしていますが、動作させることができません。私はXAMLとバックエンドコードでそれを渡してみましたが、コンボボックスは常に空白です。どんな助けもありがとう。c#wpfコンボボックスをSQL Serverデータベースにバインド

SQL Serverの(ローカル)データベース: "Database1を"

データソース:(DATASET1)。テーブル:(ProjectTable);

コンボボックス名: "ProjectComboBox"

はここに私のXAMLコードです:

<Window x:Class="WpfApplication1.MainWindow" 
    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:WpfApplication1" 
    mc:Ignorable="d" 
    Title="MainWindow" Height="500" Width="850"> 
<Grid> 
    <ComboBox x:Name="ProjectComboBox" 
       ItemsSource="{Binding Path=ProjectTable}" 
       DisplayMemberPath="ProjectName" 
       SelectedValuePath="RFIDirectory" 
       HorizontalAlignment="Left" 
       VerticalAlignment="Top" 
       Width="297" Height="26" 
       SelectionChanged="comboBox_SelectionChanged"> 
    </ComboBox> 

そしてここでは、私のバックエンドのコードです:

namespace WpfApplication1 

public partial class MainWindow : Window 
{ 
    public DataSet1 ProjectTable { get; set; } 
    public MainWindow() 
    { 
     InitializeComponent(); 

    private void comboBox_SelectionChanged(object sender, SelectionChangedEventArgs e) 
    { 
     ProjectComboBox.Items.Clear(); 

     SqlConnection con = new SqlConnection("Data Source=(local);Initial Catalog=Database1;Integrated Security=True"); 

     try 
     { 
      con.Open(); 
     } 
     catch (Exception ex) 
     { 
      MessageBox.Show(ex.ToString()); 
     } 
     try 
     { 
      SqlDataAdapter ProjectTableTableAdapter = new SqlDataAdapter("SELECT * FROM PROJECTNAME", con); 
      DataSet1 ds = new DataSet1(); 
      ProjectTableTableAdapter.Fill(ds, "t"); 

      ProjectComboBox.ItemsSource = ds.Tables["t"].DefaultView; 
      ProjectComboBox.DisplayMemberPath = "ProjectName"; 
      ProjectComboBox.SelectedValuePath = "RFIDirectory"; 

     } 
     catch (Exception ex) 
     { 
      MessageBox.Show(ex.ToString()); 
     } 

    } 
} 

}

+1

あなたはそれが何に変更することはできませんので、コンボボックスが空であるため発火することはありません 'comboBox_SelectionChanged'、中にコンボボックスを移入しています。 'InitializeComponent();'の後ろに '' 'がないことを願っています。 –

答えて

0
  1. あなたが直接結合することはできませんSQL Serverのテーブルレコード。しかし、テーブルレコードを表すオブジェクトのリストにバインドすることができます。
  2. @Paul Abbottが述べたように、フォームが読み込まれると、まずコンボボックスの項目を初期化する必要があります。またはこれを行う醜い方法は、ダミーのレコードを追加することですし、選択したイベントが発生し、コードが実行されます。
  3. 接続オープンおよびSQLデータアダプタ用に個別のtry-catchブロックを実行しないでください。冗長です。

  4. SQL接続で文を使用して、適切に閉じて後処理してください。

    public MainWindow() 
    { 
        InitializeComponent(); 
        UpdateItems(); // Maybe initialize here? 
    } 
    
    private void comboBox_SelectionChanged(object sender, SelectionChangedEventArgs e) 
    { 
        ProjectComboBox.Items.Clear(); // Remove this. AFAIK, the selected item will be cleared. 
        UpdateItems(); 
    } 
    
    private void UpdateItems() 
    { 
        try 
        { 
         using(SqlConnection con = new SqlConnection("Data Source=(local);Initial Catalog=Database1;Integrated Security=True")) 
         { 
          con.Open(); 
          SqlDataAdapter ProjectTableTableAdapter = new SqlDataAdapter("SELECT * FROM PROJECTNAME", con); 
          DataSet1 ds = new DataSet1(); 
          ProjectTableTableAdapter.Fill(ds, "t"); 
    
          ProjectComboBox.ItemsSource = ds.Tables["t"].DefaultView; 
          ProjectComboBox.DisplayMemberPath = "ProjectName"; 
          ProjectComboBox.SelectedValuePath = "RFIDirectory"; 
         } 
        } 
        catch (Exception ex) 
        { 
         MessageBox.Show(ex.ToString()); 
        } 
    } 
    
    <ComboBox x:Name="ProjectComboBox" 
         ItemsSource="{Binding Path=ProjectTable}" // Not sure of what the impact will be by adding this because you have already defined the item source on your code-behind. I'd prefer you remove this and use XAML binding when you're following a design pattern like MVVM or MVPVM. 
         DisplayMemberPath="ProjectName" 
         SelectedValuePath="RFIDirectory" 
         HorizontalAlignment="Left" 
         VerticalAlignment="Top" 
         Width="297" Height="26" 
         SelectionChanged="comboBox_SelectionChanged"> 
    </ComboBox> 
    
関連する問題