我正在尝试运行自定义查询,并且我正在使用实体框架,我尝试了这个
string query = @"SELECT dm.DistrictName,sm.SchoolName,u.UserId,u.FirstName,u.LastName, sa.StudentId, sa.ReadingLevel
FROM studentassessment sa
INNER JOIN assessmentmaster am ON sa.AssessmentId = am.AssessmentId
INNER JOIN studentclass sc ON sa.StudentId = sc.StudentId
INNER JOIN USER u ON sc.TeacherId = u.UserId
INNER JOIN schoolmaster sm ON u.SchoolCode = sm.SchoolCode
INNER JOIN districtmaster dm ON sm.DistrictId = dm.DistrictId
WHERE u.RoleId = 5 && sa.GradeId = " + objParam.Grade + " && sa.AssessmentPeriodId = " + x.AssessmentPeriodId + " && dm.DistrictId = " + districtCode + " && am.DRAType = '" + objParam.LanguageType + "' && am.AssessmentTypeId = 1";
var dt = db.ExecuteStoreQuery<List<object>>(query).FirstOrDefault();但是没有成功。
有没有办法从没有映射到任何对象类型的结构中的ExecuteStoreQuery中获得结果?
发布于 2013-01-29 23:57:52
不是的。EF的ExecuteStoreQuery需要具有与查询结果集中的列相同名称的属性的数据类型(类)。如果希望在不为结果集创建特殊类型情况下执行查询,则必须直接使用ADO.NET和SqlDataReader。
https://stackoverflow.com/questions/14585082
复制相似问题