SQL Server创表权限

本文介绍了作者在SQL Server中遇到创表权限问题并进行研究的过程。内容涉及模式(schema)和角色(role)的概念,以及如何在管理员权限下为普通用户提供创表权限。关键在于除了CREATE TABLE权限,还需要ALTER ON SCHEMA权限才能成功创表。文中还提到了一些相关的授权代码示例和防止误删表的权限控制问题。
摘要由CSDN通过智能技术生成

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.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值