2

3つのテーブルを持つDBがあります。

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();

上記のクエリの結果を、コードを作成するか、デザインモードに設定して、EntityDataSourceを使用してGridviewに表示する必要があります。

これは私の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>

助けていただければ幸いです、ありがとう。

4

1 に答える 1

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

于 2012-06-04T11:17:29.677 に答える