对象'Driver'上的INSERT权限被拒绝

时间:2013-07-12 14:12:19

标签: tsql sql-server-express sql-server-2008

我正在尝试从SQL Server Management Studio运行以下脚本:

INSERT [Truck].[Driver] ([DriverId], [CorporationId], [DriverNumber], [Name], [PhoneNumber]) 
VALUES (N'b78f90a6-ed6d-4f0e-9f35-1f3e9c516ca9', N'0a48eeeb-37f6-44de-aff5-fe9107d821f5', N'12', N'Unknown', NULL)

我收到了这个错误:

  

Msg 229,Level 14,State 5,Line 1
  对象'Driver',数据库'SuburbanPortal2',架构'Truck'拒绝INSERT权限。

我可以在编辑模式下手动添加它,但我没有错误。我拥有为用户设置的每项权限。这是一个以本地用户身份登录的本地数据库,我正在测试一些数据,因此我不太关心安全性。

但是,以下是我的用户的数据库设置:

enter image description here

enter image description here

enter image description here

有什么建议吗?

1 个答案:

答案 0 :(得分:4)

-- Use master
USE msdb;
go

-- Make database
CREATE DATABASE SuburbanPortal2;
go

-- Use the database
USE SuburbanPortal2;
GO

-- Make schema
CREATE SCHEMA Truck AUTHORIZATION dbo;
go

-- Make table
CREATE TABLE Truck.Driver
(
    [DriverId] uniqueidentifier,
    [CorporationId] uniqueidentifier,
    [DriverNumber] varchar(64),
    [Name] varchar(128),
    [PhoneNumber] varchar(12)
);

-- Add data
INSERT [Truck].[Driver] ([DriverId], [CorporationId], [DriverNumber], [Name], [PhoneNumber]) 
VALUES (N'b78f90a6-ed6d-4f0e-9f35-1f3e9c516ca9', N'0a48eeeb-37f6-44de-aff5-fe9107d821f5', N'12', N'Unknown', NULL);
GO

此代码会像您一样设置示例数据库。我对插入没有任何问题。

谁是架构的所有者?

如果要隐藏一个数据库组和另一个数据库组中的表,请将您的用户添加到数据库组。

使数据库组成为架构的所有者。我想你可能有架构所有权问题......

你可以钻进数据库 - >安全 - >架构 - >卡车,右键单击并显示架构的所有者。请发布图片。

此外,从db_owner除外的用户删除所有数据库权限。