加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 实体框架本机sql映射到类

发布时间:2020-12-15 22:01:12 所属栏目:百科 来源:网络整理
导读:我首先获得了一个代码EF,我想使用本机sql来处理更复杂的select语句. 当我尝试执行时: using (VaultsDbContext db = new VaultsDbContext()){ var contracts = db.Contracts.SqlQuery("select * from Contracts").ToListContract();} 我有: Cannot create a
我首先获得了一个代码EF,我想使用本机sql来处理更复杂的select语句.
当我尝试执行时:

using (VaultsDbContext db = new VaultsDbContext())
{
   var contracts = db.Contracts.SqlQuery("select * from Contracts").ToList<Contract>();
}

我有:

Cannot create a value for property ‘MetaProps’ of type
‘DskVault.Models.DbModels.MetaProps’. Only properties of primitive or
enumeration types are supported.

MetaProps是一个包含deleteflag,creator等的类,它是我所有类的属性.它没有映射到不同的表,每个表都有deleteflag,createor等.

public class Contract
{
    public long Id { get; set; }
    ...
    public MetaProps MetaProps { get; set; }
}

有没有办法从本机sql映射到类,如果类包含复杂类型或EF不支持?如果复杂类型是实体映射到另一个表(连接),该怎么办?

编辑:
版本:实体框架6

解决方法

我从经验中知道,并非您的表中的所有字段都必须包含在您的模型中.在将更新安装到生产环境中时,这是一件好事. 您是否尝试使用Entity Framework Power工具在SEPARATE临时项目上对表进行逆向工程?这是一个Nuget包,我发现它在代码优先编程时非常有用.反向工程将覆盖现有文件,因此请确保不要在实时代码上执行此操作.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读