1. 背景
最近老板让我给SQL数据库中插入数据,但是我创表语句一直无法通过,由此引发了我对SQL Server授权机制的研究。在我查阅了官方文档和很多资料后,在此做一个总结。其中涉及到模式(schema)和角色(role)的概念。首先,老板拥有管理员权限,我使用一个账号登录。
2. 解决方案
在管理员权限下,给用户授权创表,如下,没有报错
1> GRANT CREATE TABLE TO [test_login]
2> go
1>
普通用户尝试创表报错,如下
1> CREATE TABLE test_tb(id int)
2> go
Msg 2760, Level 16, State 1, Server DESKTOP-VBKHGJS, Line 1
The specified schema name "dbo" either does not exist or you do not have permission to use it.
1>
管理员授予更多的权限,如下
1> GRANT ALTER ON SCHEMA :: dbo TO test_login
2> go
1>
此权限来自于:https://www.