EntityDataSource запрос внутреннего соединения
У меня есть БД с 3 таблицами:
User{UserId,UserName}
Role{RoleId,RoleName}
User_Role{UserId,RoleId}
Этот запрос:
int userIdPassByUrl = 0;
MyDbContext ctx = new MyDbContext();
var query = (from role in ctx.Role
join userRole in ctx.User_Role on role.RoleId equals userRole.RoleId
where userRole.UserId == userIdPassByUrl
select new { role.RoleId, role.RoleName }).Distinct();
Мне нужно показать результат вышеупомянутого запроса в Gridview с EntityDataSource, либо кодировать или установить его в режиме разработки.
это мой EntitydataSource:
<asp:EntityDataSource ID="EdsRolesByUser" runat="server"
ConnectionString="name=myDbEntities"
DefaultContainerName="myDbEntities" EnableFlattening="False"
EntitySetName="Roles" EntityTypeFilter="Role"
Select="it.[RoleId], it.[RoleName]">
</asp:EntityDataSource>
Любая помощь будет оценена, спасибо.
1 ответ
Решение
Наконец то понял. Необходимо изменить EntityDataSource, удалив атрибуты EntitySetName и EntityTypeFilter, и добавить CommandText следующим образом:
CommandText="SELECT DISTINCT userRole.RoleId, role.RoleName FROM Role AS role
INNER JOIN User_Role as userRole
ON role.RoleId = userRole.RoleId
WHERE userRole.UserId = @UserIdPassbyUrl"
Эта ссылка поможет мне: http://msdn.microsoft.com/en-us/library/aa697427(v=vs.80).aspx