C#,Winform绑定实体框架(Entity Framework)的实体,如何去掉或隐藏导航属性?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#,Winform绑定实体框架(Entity Framework)的实体,如何去掉或隐藏导航属性?相关的知识,希望对你有一定的参考价值。

以Northwind数据库为例,要绑定的是Employees表,但是因为它与Order表有外键关系,所以在绑定到Datagridview的时候,后面Order这样的列,这是不希望看到的,有什么办法可以去掉或者隐藏?要求是不用手动去设置每一个字段。

参考技术A 明白您的意思了,您是想不加载外键的类的那些字段是吗?那简单啊,在设计模型时,就选择不延迟加载就可以了。举例:from c in edm.Employees where c.ID==1 select c;这样就只加载Employees表的数据了。

另外,如果一个表里有特别大的字段,可以把一个表映射成两个实体,如一个新闻表的标题和内容,内容这个大字段仅在看新闻时才加载才比较实际。追问

NorthwindEntities en = new NorthwindEntities();
var v = from arr in en.Employees
select arr;
foreach (Employee em in v as IEnumerable)
我这样还是一样的效果,哪里错了?

追答

foreach (Employee em in v)


先输出试试;

你是不是在设计模型的时候就是延迟加载的呢

追问

我不太懂你的延迟加载是什么意思;你能不能帮忙做一个示例,发压缩代码到附件?最好是针对Northwind,Employee 只要可行我就采纳你。

追答

延迟加载就是你一旦引用了导航属性,即使没有查询过,EF系统会自动连接数据库给你查的。

1:无延迟加载时
var m = from c in edm.Employees where c.ID==1 select c;
引用 m.Order.ID 就会出错,因为没有加载order表。
2. 迟加载时
var m = from c in edm.Employees where c.ID==1 select c;
引用 m.Order.ID 时,不出错,系统会自动连接数据库查询数据。

这个延迟加载是模型设计时是默认选中的。所以你绑定的时候是不是无意的引用了Order表里德属性了呢

追问

谢了,不过可以做demo么?

追答

我已经转行好久不弄了,记得也不多了嘿嘿。

参考技术B 你是直接用datatable作为数据集绑定到datagridview的么?可以在绑定完以后,把这一列的visable设为false,不过也是需要一列一列去设置的。或者就是查询的时候,不需要的列就不查询出来追问

似乎等于是没回答。

追答

你总归还是要有个地方告诉程序你哪列要展示,哪列不展示,要么制定规则,要么就是一列一列设置,你还想要怎么样?

追问

这样说吧,如果是直接用adapter填充的datatable,那为什么绑定的就只有sql里面的字段呢?明显datatable的属性不止那些啊,比如说tablename属性?这说明绑定自动识别了该绑定的字段。
而在entity framework里面,我想也应该有那么一种机制,可以只绑定当前表的字段,而不包括导航属性以及其他乱七八糟的属性,我想问的是有没有这种机制,如果没有就不用回答。

参考技术C 用反射,如果是复杂属性就过滤掉。放在一个通用类里,写上想要的各种过滤方法,返回一个新的匿名对象的集合。 参考技术D NorthwindEntities en = new NorthwindEntities();
var v = from arr in en.Employees
select new 
    arr.Id,    // 填写Employees的显示列
    arr.Name

追问

这样就是手动去设置了。

追答

这样是不用手动设置的,已经测试过了!!

追问

你上面写了id和name属性,如果我有100个属性,岂不是要敲死人了?

追答

那你一行代码都别写了。

第5个回答  2013-07-23 直接不绑定到字段不得了

C# Winform 关于ListView控件绑定DataTable

今天用到ListView控件,这里总结一下ListView控件绑定DataTable的方法

下面需要特别注意的是,绑定的过程中实现绑定控件的column的属性,再进行item的绑定。

与DataGridView不同的是,不能直接使用DataSourse绑定,

再者,绑定第一个Items的时候一定要实例化一个Item进行单独绑定,因为第一个Item与后面的不用即Item与SubItem的区别,下面的代码中也给出了相应的注释

 

[csharp] view plain copy
 
  1. private void LoadData()  
  2.        {  
  3.            string sql = @"select * from room";  
  4.            DataTable dt = DBUtil.getDataTable(sql);  
  5.   
  6.            this.listView1.Columns.Clear();  //好习惯,先清除再添加保证数据的一致性  
  7.            this.listView1.Columns.Add("roomid");   
  8.            this.listView1.Columns.Add("typeids");  
  9.            this.listView1.Columns.Add("price");  
  10.   
  11.            this.listView1.Items.Clear();  
  12.   
  13.            int length = dt.Rows.Count;  
  14.   
  15.            for (int i = 0; i < length; i++)  
  16.            {  
  17.                ListViewItem lvi = new ListViewItem(dt.Rows[i]["roomid"].ToString());  //ListView的第一个Item作为主项需要单独添加  
  18.   
  19.                string typeid = dt.Rows[i]["typeids"].ToString();  
  20.   
  21.                switch (typeid)  
  22.                {  
  23.                    case "1":  
  24.                        lvi.ImageIndex = 0;   //设置每个Item类型绑定的图片类型  
  25.                        break;  
  26.                    case "2":  
  27.                        lvi.ImageIndex = 1;  
  28.                        break;  
  29.                    case "3":  
  30.                        lvi.ImageIndex = 2;  
  31.                        break;  
  32.   
  33.                    default:  
  34.                        break;  
  35.                }  
  36.   
  37.                lvi.SubItems.Add(dt.Rows[i]["typeids"].ToString());   //后面添加的Item都为SubItems ,即为子项  
  38.                lvi.SubItems.Add(dt.Rows[i]["price"].ToString());  
  39.                this.listView1.Items.Add(lvi);//最后进行添加  
  40.            }  
  41.        }  

以上是关于C#,Winform绑定实体框架(Entity Framework)的实体,如何去掉或隐藏导航属性?的主要内容,如果未能解决你的问题,请参考以下文章

将实体框架对象绑定到 Datagridview C#

C# WinForm Combobox 赋值

我的 C# 实体框架项目出没了吗?

c# winform DataGridView添加一行,添加数据后,保存到数据库

通过动态调用(获取)属性来初始化(实体)对象。实体框架,c#,ASP>NET

实体框架 DBContext 数据绑定问题