首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >EntityDataSource查询内连接

EntityDataSource查询内连接
EN

Stack Overflow用户
提问于 2012-06-04 16:58:08
回答 1查看 6.5K关注 0票数 2

我有一个包含3个表的数据库:

代码语言:javascript
复制
User{UserId,UserName}
Role{RoleId,RoleName}
User_Role{UserId,RoleId}

此查询:

代码语言:javascript
复制
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();

我需要在具有EntityDataSource的网格视图中显示上述查询的结果,代码或将其设置为设计模式。

这是我的EntitydataSource:

代码语言:javascript
复制
<asp:EntityDataSource ID="EdsRolesByUser" runat="server" 
        ConnectionString="name=myDbEntities"
        DefaultContainerName="myDbEntities" EnableFlattening="False"
        EntitySetName="Roles" EntityTypeFilter="Role"
        Select="it.[RoleId], it.[RoleName]">
    </asp:EntityDataSource>

任何帮助都会很感谢,谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-06-04 19:17:30

终于明白了。我必须修改删除EntitySetName和EntityTypeFilter属性的EntityDataSource,并像这样添加CommandText:

代码语言:javascript
复制
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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10878713

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档