SQL Server 2016更改对象所有者

本教程将介绍SQL Server 2016更改对象所有者的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

SQL Server 2016更改对象所有者 教程 第1张

问题描述

我继承了一个SQL 2008 dBASE,它的所有对象都以开发人员作为所有者的名称作为前缀,即ownername.sp_get_all_USERS。

我已将dBASE还原到SQL Server 2016 Express Edition。

有数百个dBASE对象,有什么办法自动将对象所有者更改为dbo,而不是手动编辑每个对象?

我尝试过以下操作,但自SQL Server 2005以来,您显然不能再对对象进行即席更改?

SELECT * from sysobjects where uid = user_id('UseNAme')
declare @Return int
exec @Return = sp_configure 'allow updates', '1'
SELECT @Return as 'Returned Code'
GO
reconfigure WITH OVERRIDE
GO
DECLARE @Rows int, @Error int
BEGIN TRANSACTION
update sysobjects set uid = user_id('dbo') where uid = user_id('UseNAme')
SELECT @Error = @@Error, @Rows = @@RowCount
SELECT @Rows as '#Rows'
IF @Rows > 0
 BEGIN  SELECT  @Rows AS '#Rows'
  COMMIT TRANSACTION
 END
else 
 BEGIN
  SELECT @Error AS 'Error #'
  ROLLBACK TRANSACTION
 END

exec sp_configure 'allow updates', '0'
reconfigure WITH OVERRIDE
go

最感谢的任何帮助。

推荐答案

您必须使用更改架构...

ALTER SCHEMA oldschemaname TRANSFER dbo.Address; 

自动使用下面的

这会将具有非SYSTEM架构的所有表更改为dbo,请注意,如果您有两个不同架构的表,则它们不能存在于同一架构中

select *,row_number() over (order by (select null)) as rownum
into #tables
 from information_Schema.tables
where table_schema in (select name  from sys.schemas
 where name  not in ('dbo','guest','INFORMATION_SCHEMA','sys') and principal_id <16384
 )

now move 
declare @min int,@max int

select @min=min(rownum),@max=max(rownum)
from #tables

declare @tblname varchar(255),@schemaname sysname
declare @sql varchar(max)

while @min<=@max
Begin

select @tblname=table_name,@schemaname=table_schema from
#tables where rownum=@min

set @sql='alter schema dbo transfer '+ @schemaname+'.'+@tblname

--print @sql
exec(@sql)

Set @min=@min+1
End

sp_根据文档说明更改对象所有者..

此存储过程仅适用于MicrosoftSQL Server2000中可用的对象。此功能将在Microsoft SQL Server的未来版本中删除。避免在新的开发工作中使用此功能,并计划修改当前使用此功能的应用程序。请改用ALTER SCHEMA或ALTER AUTHORIZATION。Sp_changeobjecowner同时更改架构和所有者。为了保持与早期版本的SQL Server的兼容性,仅当当前所有者和新所有者都拥有与其数据库用户名同名的架构时,此存储过程才会更改对象所有者。

好了关于SQL Server 2016更改对象所有者的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。