Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 3274498
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 17, 20262026-05-17T19:02:42+00:00 2026-05-17T19:02:42+00:00

I have many security accounts on the sql database and i want to remove/add

  • 0

I have many security accounts on the sql database and i want to remove/add roles to them based on a simple string comparison.

  1. Basically i want to list all
    accounts
  2. Filter out accounts that DON’T start
    with “MyDomain\”
  3. Remove role A.
  4. Add role B.

What i found out by now is that i use sp_helprolemember to list all the accounts and sp_addrolemember and sp_droprolemember. My problem is that i dont know how to “get” the output from sp_helprolemember and work with it.

My first attemt at a soltuion based of feedback.

DROP TABLE [dbo].[XTemp]
create table XTemp(DbRole sysname,MemberName sysname,MemberSID varbinary(85) )

insert XTemp exec sp_helprolemember 
select * from XTemp

I made a permanent table to make it simpler to test and debug.

SELECT [DbRole]
      ,[MemberName]
      ,[MemberSID]
  FROM [ARTICLE].[dbo].[XTemp]
  WHERE MemberName like Domain\%'
    exec sp_addrolemember 'OldRole MemberName
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-17T19:02:43+00:00Added an answer on May 17, 2026 at 7:02 pm

    Assuming that you’re using SQL 2005 or later, and executing sp_helprolemember without parameters, this is the query that sp_helprolemember runs (extracted using sp_helptext):

      select DbRole = g.name, MemberName = u.name, MemberSID = u.sid  
       from sys.database_principals u, sys.database_principals g, sys.database_role_members m  
       where   g.principal_id = m.role_principal_id  
        and u.principal_id = m.member_principal_id  
       order by 1, 2  
    

    This should enable you to collect the information you need into a temp table.

    If you’d rather stick to documented behaviour, you can store the output of the SP into a temp table:

    create table #t
    (DbRole sysname,
    MemberName sysname,
    MemberSID varbinary(85) 
    )
    
    insert #t
    exec sp_helprolemember 
    
    select * from #t
    

    EDIT

    There are two ways to use this data to amend your system. One is using a cursor:

    DECLARE @memberName sysname
    
    DECLARE curMember CURSOR fast_forward FOR
    SELECT  MemberName
    FROM #t 
    WHERE MemberName LIKE 'Domain\%' 
    
    OPEN curMember
    
    FETCH NEXT FROM curMember INTO @memberName
    
    WHILE @@FETCH_STATUS = 0
    BEGIN
    
        EXEC sp_addrolemember 'OldRole', @memberName
        FETCH NEXT FROM curMember INTO @memberName
    
    END
    
    CLOSE curMember
    DEALLOCATE curMember
    

    The other is using dynamic SQL:

    DECLARE @sql NVARCHAR(MAX),
    
    SELECT @sql = 'EXEC sp_addrolemember ''OldRole'', ''' + MemberName + ''''
    FROM #t
    WHERE MemberName LIKE 'Domain\%' 
    
    EXEC sp_executesql @stmt = @sql
    

    As you can see the dynamic SQL version is more compact but requires more effort to maintain.

    Remember that after you execute either statement, the data you extracted from sp_helprolemember into a table is no longer up to date, and should probably be refreshed.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

As many of you probably know, online banks nowadays have a security system whereby
I have many items inside a list control. I want each item to have
I have many small files containing code fragments, pseudo-code algorithms, classes, templates, SQL-samples, etc.,
I have many years of experience in Java including Swing, Servlet and JDBC, but
I have many emails coming in from different sources. they all have attachments, many
I have many jobs that have a step to send 1 specific email out
We have many projects that use a common base of shared components (dlls). Currently
I have many different branches/checkouts of the same project code on my development machine.
I have many sites that use the same root category of the Main Site.
I have many requires and includes and i was wondering if there's something that

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.