解决EF使用context.Database.SqlQuery时NotMapped属性列为空null的问题
2017-11-20 13:45
337 查看
有时候我们要为EF中的Model加一个新属性,这个属性不是数据库中的字段,而是从其它表中关联出来的。EF中要标示一个列不是对应表中字段只需要加上NotMapped特性。要使用NotMapped,保证你的项目引用了System.ComponentModel.DataAnnotations.dll,NotMapped特性在命名空间System.ComponentModel.DataAnnotations.Schema下。比如我们有一个Employee实体:
可能你会想到用context.Database.SqlQuery写一句原生的sql为CustomerName赋值,就像下面的代码:
但是遗憾是上面代码字段CustomerName始终都为空。因为使用context.Database.SqlQuery虽然是传的sql语句,但是它和原生的ADO.NET还是不一样,它还是会走一下EF框架,用NotMapped标示的字段,EF会忽略掉这个字段,当生成sql语句也不会包含这个字段,无论你增,改,查都不会管这个字字段,所以读出来始终为空null值。下面介绍一种利用linq的变通的办法。
调用EF并使用linq的left join读取属性:
https://www.lanhusoft.com/Article/247.html
public class Employee { public int EmployeeId { get; set; } public string EmployeeName { get; set; } [NotMapped] public string CustomerName { get; set; } }
可能你会想到用context.Database.SqlQuery写一句原生的sql为CustomerName赋值,就像下面的代码:
public List<Employee> GetEmployees() { using (MyContext context = new MyContext()) { return context.Database.SqlQuery<Employee>("select E.EmployeeId, E.EmployeeName, C.CustomerName from Employee E left join Customer C on E.CustomerId = C.CustomerId").ToList(); } }
但是遗憾是上面代码字段CustomerName始终都为空。因为使用context.Database.SqlQuery虽然是传的sql语句,但是它和原生的ADO.NET还是不一样,它还是会走一下EF框架,用NotMapped标示的字段,EF会忽略掉这个字段,当生成sql语句也不会包含这个字段,无论你增,改,查都不会管这个字字段,所以读出来始终为空null值。下面介绍一种利用linq的变通的办法。
public class EmployeeVM { public int EmployeeId { get; set; } public string EmployeeName { get; set; } public string CustomerName { get; set; } }
调用EF并使用linq的left join读取属性:
public List<Employee> GetEmployees() { using (MyContext context = new MyContext()) { return context.Database.SqlQuery<EmployeeVM>("select E.EmployeeId, E.EmployeeName, C.CustomerName from Employee E left join Customer C on E.CustomerId = C.CustomerId") .Select(x=> new Employee(){ EmployeeId = x.EmployeeId, EmployeeName = x.EmployeeName, CustomerName = x.CustomerName }).ToList(); } }
https://www.lanhusoft.com/Article/247.html
相关文章推荐
- EF(Entity Framework)发生错误”正在创建模型,此时不可使用上下文“的解决办法。 正在创建模型,此时不可使用上下文。如果在 OnModelCreating 方法内使用上下文或如果多个线程同时访问同一上下文实例,可能引发此异常。请注意不保证 DbContext 的实例成员和相关类是线程安全的。 临时解决了这个问题,在Context的构造函数中,禁用了自动初始化:
- html:optionsCollection 的 filter 过滤属性使用心得 - 解决空格不能显示的问题
- 多线程中使用HttpContext.Current为null的解决办法
- 解决GeoServices发布带有中文属性字段的shp文件出现无法使用sld文件的问题
- 使用CDI规范中的@Named标注jsf bean时,引发null问题的解决
- Microsoft JET Database Engine 错误 '80004005' 操作必须使用一个可更新的查询。问题解决办法
- DBMS_SESSION.SET_CONTEXT的使用及无效权限问题的解决
- 解决Entity Framework(EF) 使用时,数据库结构对应,但EF还是提示要删除数据库的问题
- 数据值为NULL,导致条件查询不到正确结果,ISNULL函数的使用解决问题
- IE兼容问题解决根源:深刻理解hasLayout属性,原理与使用方法
- opengl的surfaceview使用findViewById返回null问题解决
- mongo-node 利用eval属性完成数据库的增删改(可以使用mongodb的原生语言,解决ID自增问题)
- 使用IBatisNet的网站,修改database.config无效的问题解决
- 主流浏览器下 定义小于18px高度属性height的盒子再次测试 使用overflow解决问题
- min-height 属性的使用以及IE6.0不兼容问题的解决办法
- IE兼容问题解决根源:深刻理解hasLayout属性,原理与使用方法
- android TextView多行文本(超过3行)使用ellipsize属性无效问题的解决方法
- SuperMap属性表操作中遇到的Query结果为null的问题分析及解决
- Struts 2 使用属性模型取checkbox 值出现问题解决方法。
- DBMS_SESSION.SET_CONTEXT的使用及无效权限问题的解决