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里面,我想也应该有那么一种机制,可以只绑定当前表的字段,而不包括导航属性以及其他乱七八糟的属性,我想问的是有没有这种机制,如果没有就不用回答。
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的区别,下面的代码中也给出了相应的注释
- private void LoadData()
- {
- string sql = @"select * from room";
- DataTable dt = DBUtil.getDataTable(sql);
- this.listView1.Columns.Clear(); //好习惯,先清除再添加保证数据的一致性
- this.listView1.Columns.Add("roomid");
- this.listView1.Columns.Add("typeids");
- this.listView1.Columns.Add("price");
- this.listView1.Items.Clear();
- int length = dt.Rows.Count;
- for (int i = 0; i < length; i++)
- {
- ListViewItem lvi = new ListViewItem(dt.Rows[i]["roomid"].ToString()); //ListView的第一个Item作为主项需要单独添加
- string typeid = dt.Rows[i]["typeids"].ToString();
- switch (typeid)
- {
- case "1":
- lvi.ImageIndex = 0; //设置每个Item类型绑定的图片类型
- break;
- case "2":
- lvi.ImageIndex = 1;
- break;
- case "3":
- lvi.ImageIndex = 2;
- break;
- default:
- break;
- }
- lvi.SubItems.Add(dt.Rows[i]["typeids"].ToString()); //后面添加的Item都为SubItems ,即为子项
- lvi.SubItems.Add(dt.Rows[i]["price"].ToString());
- this.listView1.Items.Add(lvi);//最后进行添加
- }
- }
以上是关于C#,Winform绑定实体框架(Entity Framework)的实体,如何去掉或隐藏导航属性?的主要内容,如果未能解决你的问题,请参考以下文章
c# winform DataGridView添加一行,添加数据后,保存到数据库