0

特別なユーザー名の役割名を更新するこのクエリで何を変更する必要がありますか?実行後のこのクエリにより、すべてのロール名が更新されました!!ユーザー名を考慮せずに!! そして、私はそれを望まないので、私を導いてください。ありがとう

UPDATE 
    aspnet_Roles
SET 
    RoleName = @RoleName
FROM 
    aspnet_Membership 
INNER JOIN
    aspnet_Users ON aspnet_Membership.UserId = aspnet_Users.UserId 
INNER JOIN
    aspnet_UsersInRoles ON aspnet_Users.UserId = aspnet_UsersInRoles.UserId 
INNER JOIN
    aspnet_Roles ON aspnet_UsersInRoles.RoleId = aspnet_Roles.RoleId
WHERE       
    (aspnet_Users.UserName = @UserName)
4

1 に答える 1

0

それはメンバーシップテーブルであり、私は解決策を見つけました。ここは :

 sqlcmd = new SqlCommand("SELECT RoleId FROM  aspnet_Roles where RoleName=@RoleName", sqlconn);
                        sqlcmd.Parameters.AddWithValue("@RoleName", "Reviewer");

                        sqlconn.Open();
                        System.Guid RoleId = ((System.Guid)sqlcmd.ExecuteScalar());

                        sqlcmd = new SqlCommand("SELECT UserId FROM  aspnet_Users where UserName=@UserName", sqlconn);
                        sqlcmd.Parameters.AddWithValue("@UserName", EditorUserName);
                        System.Guid UserId = ((System.Guid)sqlcmd.ExecuteScalar());

                        sqlcmd = new SqlCommand("SELECT RoleId FROM  aspnet_Roles where RoleName=@RoleName", sqlconn);
                        sqlcmd.Parameters.AddWithValue("@RoleName", "ReviewerEditor");
                        System.Guid ReviewerEditorRoleId = ((System.Guid)sqlcmd.ExecuteScalar());

                        sqlconn.Close();

                        ///  ///////////////////////////////////////////////////////////////////////////////////////////////////////////////

                        sqlcmd = new SqlCommand("UPDATE  aspnet_UsersInRoles SET RoleId = @RoleId WHERE (UserId= @UserId)", sqlconn);
                        sqlcmd.Parameters.AddWithValue("@RoleId", ReviewerEditorRoleId);
                        sqlcmd.Parameters.AddWithValue("@UserId", UserId);
                        sqlconn.Open();
                        sqlcmd.ExecuteNonQuery();
                        sqlconn.Close();
于 2012-11-19T08:47:30.170 に答える