sql server grant, revoke permission to a user

后端 未结 3 1911
挽巷
挽巷 2021-01-25 19:15

I wrote a simple c# code that connect to sql-server database and execute a query:

        cmd = new SqlCommand(txtQuery.Text.ToString().Trim(), con);
        cmd         


        
相关标签:
3条回答
  • 2021-01-25 19:37

    You cannot REVOKE something you did not GRANT. Looks like you want to:

    1. investigate and understand why user2 has permission to SELECT
    2. possibly DENY permission to SELECT to user2

    The permission work like following:

    • initialy an user has the poermissions derived from his group mebership (including public roles)
    • GRANT explictly grants a privilege
    • REVOKE takes back a previously granted priviledge, reverting to the user having the privileges implictily inherited from group(s) memberhip
    • DENY denies a privilege

    The rules of precedence are that any DENY take precedence over any GRANT or inherited privilege. One can get access through a number of GRANTs but one single DENY will revoke the privilege. You cannot GRANT/REVOKE/DENY permissions to the securable owner (members of db_owner own everything and members of sysadmin own everything on the entire server).

    0 讨论(0)
  • 2021-01-25 19:43

    user2 is probably getting it's permissions from a role membership.

    Run:

    use [<YourDatabase>]
    GO
    
    exec sp_helpuser
    

    find the user in the first column, and then look at the second column. Is the user a member of db_datareader or db_owner?

    If so, you can revoke membership, say for db_datareader, by doing:

    exec sp_droprolemember 'db_datareader', 'user2'
    GO
    
    0 讨论(0)
  • 2021-01-25 19:44

    Thanks friends, I've solved it and use DENY instead of REVOKE :

    DENY select ON user1.myTB TO user2

    0 讨论(0)
提交回复
热议问题