SQL Server 2016更改对象所有者
我继承了一个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的兼容性,仅当当前所有者和新所有者都拥有与其数据库用户名同名的架构时,此存储过程才会更改对象所有者。
相关文章