在WPF中我新建了一个datagrid,我现在想把列绑定到数据库不同的表里的列,怎么实现?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在WPF中我新建了一个datagrid,我现在想把列绑定到数据库不同的表里的列,怎么实现?相关的知识,希望对你有一定的参考价值。

从数据源里拖拽一次要添加一整个表。。。自己写该怎么实现?
比如有3个表a,b,c 其中 b,c是a的子表 在datagrid里,列1显示a中的一个属性,列2,3显示对应的b,c的属性

参考技术A 这是SQL语句的问题..你可以这样..SELECT * FROM [TABLE1] A LEFT JOIN [TABLE2] B ON A.ID=B.ID LEFT JOIN [TABLE3] C ON A.ID=C.ID再把*换成你要查找的字段名..比如你要找TABLE1里面的Name字段TABLE2里面的Photo字段和TABLE3里面的Class字段你可以这样写...SELECT A.Name,B.Photo,C.Class FROM [TABLE1] A LEFT JOIN [TABLE2] B ON A.ID=B.ID LEFT JOIN [TABLE3] C ON A.ID=C.ID然后再后台写代码往DataGrid里面加数据.. 参考技术B private void fill_Datagrid(string sql)

cmd = new SqlCommand(sql, conn.getConn());
sda = new SqlDataAdapter();
sda.SelectCommand = cmd;
ds = new DataSet();
sda.Fill(ds);
dataGridView1.DataSource = ds.Tables[0];
dataGridView1.Columns[0].Visible = false;

其中sql=“select 字段 from a,b,c where 字段 =?”;
sql是在数据库中查询语句。本回答被提问者采纳

读取自定义Datagrid的每个单元格数据 - WPF C#

我已经定义了一个自定义数据网格,其列由文本框,组合框和按钮组成。我还使用XAML Binding在每个组合框中填充数据。现在,我想从数据网格中读取每个选定的组合框值和文本框值。但是我找不到任何方法来阅读它。我研究过论坛并找到与DataGridView相关的解决方案但对DataGrid来说并不多。这是我的示例代码,我将定义自定义数据网格以及如何填充其中的数据。

public class Data
{

    public List<string> Disciplines { get; set; }
    public List<string> Members { get; set; }
    public List<string> ActionType { get; set; }


    public Data()
    {
        this.Disciplines = new List<string>
        {
            "Architecture", "Mechanical", "Structure"
        };

        this.Members = new List<string>
        {
            "Ali", "Mubashar", "Muffassir", "Nitin"
        };

        this.ActionType = new List<string>
        {
            "Take Action",
            "For Information"
        };




    }
}

public MainWindow()
{
    InitializeComponent();
    datagrid_additionalinfo.Items.Add(new Data());


}

<DataGrid  Name="datagrid_additionalinfo" Margin="20,0,20,0" 
                   IsReadOnly="False" SelectionMode="Single" CanUserAddRows="True" 
                   AutoGenerateColumns="False" SelectionUnit="Cell" >


            <DataGrid.Columns>

                <DataGridTemplateColumn Header="Comment"  Width="*" MinWidth="130">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <TextBox Width="235"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn Header="Discipline"   Width="100" >
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <ComboBox Width="200" ItemsSource="{Binding Disciplines}"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn Header="Members"  Width="100">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <ComboBox Width="200" ItemsSource="{Binding Members}"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn Header="Action Type"  Width="100">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <ComboBox Width="200" ItemsSource="{Binding ActionType}"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

            </DataGrid.Columns>


  </DataGrid>

以下是自定义数据网格的样子:感谢任何帮助。谢谢

Custom Data-Grid WPF

答案

除了集合属性public List<string> Disciplines { get; set; }声明所选项目的属性

public string SelectedDiscipline { get; set; }

并将其绑定到ComboBox

<ComboBox Width="200" 
          SelectedIndex="0"
          SelectedItem="{Binding SelectedDiscipline, UpdateSourceTrigger=PropertyChanged}"
          ItemsSource="{Binding Disciplines}"/>

并为其他属性做同样的事情

这样,您无需直接使用DataGridRow单元即可访问所有值

另一答案

我看到这里有基本的理解问题。你将代码与MVVM结构混合在一起。而不是那个代码;

datagrid_additionalinfo.Items.Add(new Data());

尝试使用ObservableCollection<Data>作为ViewModel中DataGrid的ItemSource。将ViewModel用作View的DataContext。之后,您可以绑定SelectedItems。

这是代码;

MainWindow.xaml

<Window x:Class="DataGridComboBox.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:DataGridComboBox"
        mc:Ignorable="d"
        Title="MainWindow" Height="350" Width="525">
    <Grid>

        <DataGrid  Name="datagrid_additionalinfo" Margin="20,0,20,0" 
                   ItemsSource="{Binding DataItems}" 
                   SelectedItem="{Binding SelectedDataRow, UpdateSourceTrigger=PropertyChanged}"
                   IsReadOnly="False" SelectionMode="Single" CanUserAddRows="True" 
                   AutoGenerateColumns="False"  >


            <DataGrid.Columns>

                <DataGridTemplateColumn Header="Comment"  Width="*" MinWidth="130">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <TextBox Width="235"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn Header="Discipline"   Width="100" >
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <ComboBox Width="200" ItemsSource="{Binding Disciplines}" 
                                      SelectedItem="{Binding DataContext.SelectedDisipline, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Window}}, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn Header="Members"  Width="100">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <ComboBox Width="200" ItemsSource="{Binding Members}"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

                <DataGridTemplateColumn Header="Action Type"  Width="100">
                    <DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <ComboBox Width="200" ItemsSource="{Binding ActionType}"/>
                        </DataTemplate>
                    </DataGridTemplateColumn.CellTemplate>
                </DataGridTemplateColumn>

            </DataGrid.Columns>


        </DataGrid>
    </Grid>
</Window>

MainWindow.xaml.cs

    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            this.DataContext = new MainWindowViewModel(); 
        }
    }


**MainWindowViewModel**

using System.Collections.ObjectModel;
using System.ComponentModel;

...

 public class MainWindowViewModel : INotifyPropertyChanged
    {
        public event PropertyChangedEventHandler PropertyChanged;
        private ObservableCollection<Data> m_DataItems;

        public ObservableCollection<Data> DataItems
        {
            get { return m_DataItems; }
            set { m_DataItems = value; }
        }


        private Data m_SelectedDataRow;
        public Data SelectedDataRow
        {
            get { return m_SelectedDataRow; }
            set { m_SelectedDataRow = value; }
        }


        private string m_SelectedDisipline;
        public string SelectedDisipline
        {
            get { return m_SelectedDisipline; }
            set { m_SelectedDisipline = value; }
        }

        public MainWindowViewModel()
        {
            m_DataItems = new ObservableCollection<Data>();

            //Fill Items 
            Data data; 
            for (int i = 0; i < 10; i++)
            {
                data = new Data();
                m_DataItems.Add(data);
            }
        }

        private void OnPropertyChanged(string propertyName)
        {
            var handler = PropertyChanged;
            if (handler != null)
            {
                handler(this, new PropertyChangedEventArgs(propertyName));
            }
        }

    }

以上是关于在WPF中我新建了一个datagrid,我现在想把列绑定到数据库不同的表里的列,怎么实现?的主要内容,如果未能解决你的问题,请参考以下文章

Datagrid行选择事件,WPF

在wpf中怎么获取datagrid某行某列的值

如何在WPF Datagrids中修复“双向绑定需要路径或XPath”异常?

WPF DataGrid 自定义行标题

使用 MVVM 从 WPF 中的 TextBox 进行正确的 DataGrid 搜索

如何在WPF中模拟右键单击datagrid