SQL Server 2016更改对象所有者

SQL Server 2016 Change Object Owner(SQL Server 2016更改对象所有者)
本文介绍了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的兼容性,仅当当前所有者和新所有者都拥有与其数据库用户名同名的架构时,此存储过程才会更改对象所有者。

这篇关于SQL Server 2016更改对象所有者的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
SSIS: Model design issue causing duplications - can two fact tables be connected?(SSIS:模型设计问题导致重复-两个事实表可以连接吗?)
SQL Server Graph Database - shortest path using multiple edge types(SQL Server图形数据库-使用多种边类型的最短路径)
Invalid column name when using EF Core filtered includes(使用EF核心过滤包括时无效的列名)
How should make faster SQL Server filtering procedure with many parameters(如何让多参数的SQL Server过滤程序更快)
How can I generate an entity–relationship (ER) diagram of a database using Microsoft SQL Server Management Studio?(如何使用Microsoft SQL Server Management Studio生成数据库的实体关系(ER)图?)