在 SQL Server 中,内存表(也称为 In-Memory OLTP 表)是一种特殊类型的表,它们驻留在内存中而不是磁盘上
-
创建数据库用户:
首先,需要为需要访问内存表的用户创建一个数据库用户。例如,可以使用以下命令创建一个名为
User1
的用户:CREATE USER User1 WITHOUT LOGIN;
-
分配架构权限:
接下来,需要为新创建的用户分配对内存表所在架构的访问权限。例如,如果内存表位于名为
InMemorySchema
的架构中,可以使用以下命令为User1
分配访问权限:GRANT CONTROL ON SCHEMA::InMemorySchema TO User1;
-
分配表权限:
为了使用户能够执行特定操作(如 SELECT、INSERT、UPDATE 或 DELETE),需要为其分配相应的表权限。例如,可以使用以下命令为
User1
分配对名为InMemoryTable
的内存表的 SELECT 和 INSERT 权限:GRANT SELECT, INSERT ON OBJECT::InMemorySchema.InMemoryTable TO User1;
-
分配存储过程权限:
如果用户需要通过存储过程访问内存表,还需要为其分配对相应存储过程的 EXECUTE 权限。例如,可以使用以下命令为
User1
分配对名为InMemorySP
的存储过程的 EXECUTE 权限:GRANT EXECUTE ON OBJECT::InMemorySchema.InMemorySP TO User1;
通过以上步骤,可以实现对 SQL Server 内存表的权限管理。请注意,根据实际需求,可能需要为其他用户分配不同的权限。