我是一个懒人实在不想码字,但是为了.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; }