c# - 将 Entity Framework 对象绑定(bind)到 Datagridview C#

标签 c# winforms entity-framework data-binding datagridview

我一直在尝试将 Entity Framework 对象绑定(bind)到 DataGridView,但我总是遇到死胡同,似乎无法在任何地方找到我的答案。

我可以将整个表(实体)绑定(bind)到 gridview,它允许我进行更改并将这些更改保存回数据库,如下所示:

    WS_Model.WS_Entities context;

    private void simpleButton1_Click(object sender, EventArgs e)
    {
        context = new WS_Entities();

        var query = from c in context.Users select c;

        var users = query.ToList();

        gridControl1.DataSource = users;
    }

    private void simpleButton2_Click(object sender, EventArgs e)
    {
        context.SaveChanges();
    }

但我不想在我的数据 GridView 中看到我的数据库中表中的所有列,所以我尝试这样做...

WS_Entities context = new WS_Entities();

    private void simpleButton1_Click(object sender, EventArgs e)
    {
        var query = from c in context.Users
                    where c.UserName == "James"
                    select new { c.UserName, c.Password, c.Description };

        var results = query.ToList();

        gridControl1.DataSource = results;
    }

    private void simpleButton2_Click(object sender, EventArgs e)
    {
        context.SaveChanges();
    }

但现在我无法在我的 DataGridView 中编辑任何数据。

我在这里只见树木不见森林 - 请有人介意指出我们的方法错误,或者告诉我在人才流失时将 EF 与 Winforms 绑定(bind)的最佳做法是什么。

我可以看出它与该部分有关:

select new { c.UserName, c.Password, c.Description }

但我不知道为什么。

最佳答案

线路问题:

select new { c.UserName, c.Password, c.Description }

它是否正在创建一个 anonymous type , 并且匿名类型是不可变的——即只读的。这就是为什么您的更改不会反射(reflect)在新类型或原始 EF 对象中。

现在,关于不显示您绑定(bind)到的对象的所有列的方法,我在下面给出了三个选项。

隐藏不需要的列

最直接的方法是将您不想显示的列的可见属性设置为 false。

dataGridView1.Columns[0].Visible = false;

Columns 集合索引器中的值可以是指定列位置的整数或列名称的字符串。

EF 中用于此数据绑定(bind)的自定义对象

您还可以在 EF 层处理此问题 - 为您的绑定(bind)创建一个自定义对象,EF 从数据库中映射出您不需要的列。我实际上根本没有使用过 EF 4.0,但我知道它现在具有此功能。

自定义 DTO 从 EF 对象转换然后映射回来

第三个选项(在我看来,这些选项从好到坏,但我想我会告诉你一些方法!)是查询具体类型,然后映射回 EF 对象。像这样的东西:

private class DataBindingProjection
{
    public string UserName { get; set; };
    public string Password { get; set; };
    public string Description { get; set; };
}

private void simpleButton1_Click(object sender, EventArgs e)
{
    context = new WS_Entities();
    var query = from c in context.Users
                where c.UserName == "James"
                select new DataBindingProjection { UserName = c.UserName, Password = c.Password, Description = c.Description };
    var users = query.ToList();
    gridControl1.DataSource = users;
}

private void simpleButton2_Click(object sender, EventArgs e) 
{
    // and here you have some code to map the properties back from the 
    // projection objects to your datacontext

    context.SaveChanges();
}

在某些情况下,这也是一个可行的解决方案......

关于c# - 将 Entity Framework 对象绑定(bind)到 Datagridview C#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5793619/

相关文章:

c#线程访问其他线程

c# - 有没有实现类似于MSMQ(Microsoft Message Queuing)的消息队列的免费库?

c# - 如何制作表格中心的面板?

c# - Linq2Entities CompiledQuery 用于使用连接的查询

mysql - 在以下情况下是否有办法维护数据库关系(pk/fk)

c# - 如何解决这个错误 : RabbitMQ. Client.Exceptions.BrokerUnreachableException: 'None of the specified endpoints were reachable'

c# - 将 UID 属性添加到我的 XAML 文件

c# - 如何在 C# 中实现 Lua 容器(虚拟文件系统)模块加载器

c# - 将 System.Drawing 位图转换为 Dlib Array2D

entity-framework - 我可以使用 AutoMapper 将一个列表映射到另一已实例化对象的列表吗?