core ef查询结果存自定义model

解决EFCore中使用自定义Model执行SQL语句的问题,避免因未在DbContext注册而导致的错误。介绍如何在DbContext继承类中添加代码,使查询结果能正确存储在自定义Model中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我是一个懒人实在不想码字,但是为了.net core的发展还是做出自己一点微薄贡献吧。

这个问题网上搜了下,并没有找到满意答案,都是英文,实在头大。

 

ef是支持执行sql语句的,查询结果可以存储在任意的model里,到了ef core如果不在dbcontext注册就会出现如下错误:

Cannot create a DbSet for 'XXX' because this type is not included in the model for the context

public List<UserSetPersonModel> getUserSetPersons(int userID)
        {
            using (DAMSEntities db = new DAMSEntities())
            {
                string sql= "select ID,UserID,PsnID,[Type],IsView,A0101,E0101 from dbo.Sys_UserSetPerson U"+
                    " left join dbo.DA_PersBasicInfo P on U.PsnID = P.PersID"+
                    " where U.UserID = @UserID";
                SqlParameter param = new SqlParameter("@UserID",userID);
                var list= db.Set<UserSetPersonModel>().FromSql(sql, param).ToList();                
                return list;
            }
        }

UserSetPersonModel 为自定义model,并不是从数据库映射过来的表,直接执行会报错。

需要在dbcontext继承类里增加如下代码,即可解决问题:

public virtual DbSet<UserSetPersonModel> UserSetPersonModel { get; set; }

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值