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更改对象所有者的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:SQL Server 2016更改对象所有者
基础教程推荐
猜你喜欢
- 将数据从 MS SQL 迁移到 PostgreSQL? 2022-01-01
- SQL Server 2016更改对象所有者 2022-01-01
- ERROR 2006 (HY000): MySQL 服务器已经消失 2021-01-01
- Sql Server 字符串到日期的转换 2021-01-01
- 在 VB.NET 中更新 SQL Server DateTime 列 2021-01-01
- 如何在 SQL Server 的嵌套过程中处理事务? 2021-01-01
- SQL Server 中单行 MERGE/upsert 的语法 2021-01-01
- 无法在 ubuntu 中启动 mysql 服务器 2021-01-01
- 使用pyodbc“不安全"的Python多处理和数据库访问? 2022-01-01
- SQL Server:只有 GROUP BY 中的最后一个条目 2021-01-01