我正在尝试从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权限。
我可以在编辑模式下手动添加它,但我没有错误。我拥有为用户设置的每项权限。这是一个以本地用户身份登录的本地数据库,我正在测试一些数据,因此我不太关心安全性。
但是,以下是我的用户的数据库设置:
有什么建议吗?
答案 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除外的用户删除所有数据库权限。