답변:
ALTER SCHEMA dbo TRANSFER jonathan.MovieData;
ALTER SCHEMA를 참조하십시오 .
일반화 된 구문 :
ALTER SCHEMA TargetSchema TRANSFER SourceSchema.TableName;
[DOMAIN\user].[tableName]
. 일반적으로 SQL Server 커뮤니티에서는 Transact-SQL 인용 식별자가 사용됩니다 ( [
및 ]
) "
. 특정 요구 사항이없는 한 피 하십시오.
[
과 ]
다른 경우처럼, 당신은 SQL 오브젝트 이름에 대한 정확하고 싶을 때. [domain\user123].TableName
.
다음을 실행하면 모든 탈브에 대한 ALTER sCHEMA 문 집합이 생성됩니다.
SELECT 'ALTER SCHEMA dbo TRANSFER ' + TABLE_SCHEMA + '.' + TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'jonathan'
그런 다음 쿼리 분석기에서 문을 복사하고 실행해야합니다.
여기에 당신을 위해 그렇게 할 오래된 스크립트가 있습니다. 저는 객체 소유자를 변경함으로써 생각합니다. 하지만 2008 년에는 시도하지 않았습니다.
DECLARE @old sysname, @new sysname, @sql varchar(1000)
SELECT
@old = 'jonathan'
, @new = 'dbo'
, @sql = '
IF EXISTS (SELECT NULL FROM INFORMATION_SCHEMA.TABLES
WHERE
QUOTENAME(TABLE_SCHEMA)+''.''+QUOTENAME(TABLE_NAME) = ''?''
AND TABLE_SCHEMA = ''' + @old + '''
)
EXECUTE sp_changeobjectowner ''?'', ''' + @new + ''''
EXECUTE sp_MSforeachtable @sql
이 사이트 에서 가져 왔습니다. .
필요한 경우 저장된 procs에 대해 동일한 작업을 수행하는 것에 대해서도 설명합니다.
sys.tables
대신 사용하도록 예제를 다시 작성해야합니다 (sys.objects의 하위 집합).
USE MyDB;
GO
ALTER SCHEMA dbo TRANSFER jonathan.MovieData;
GO
참조 : ALTER SCHEMA
방금 비슷한 질문에이 글을 올렸습니다 . SQL Server 2005에서 데이터 손실없이 테이블의 "스키마"를 어떻게 변경합니까?
약간 압라의 훌륭한 대답 개선 ...
이 코드가 자체 실행되도록 exec를 추가하고 맨 위에 유니온을 추가하여 두 테이블 및 저장 프로 시저의 스키마를 변경할 수 있습니다.
DECLARE cursore CURSOR FOR
select specific_schema as 'schema', specific_name AS 'name'
FROM INFORMATION_SCHEMA.routines
WHERE specific_schema <> 'dbo'
UNION ALL
SELECT TABLE_SCHEMA AS 'schema', TABLE_NAME AS 'name'
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA <> 'dbo'
DECLARE @schema sysname,
@tab sysname,
@sql varchar(500)
OPEN cursore
FETCH NEXT FROM cursore INTO @schema, @tab
WHILE @@FETCH_STATUS = 0
BEGIN
SET @sql = 'ALTER SCHEMA dbo TRANSFER [' + @schema + '].[' + @tab +']'
PRINT @sql
exec (@sql)
FETCH NEXT FROM cursore INTO @schema, @tab
END
CLOSE cursore
DEALLOCATE cursore
나도 dbdump를 복원해야했고 스키마가 dbo가 아님을 발견했습니다. Sql Server Management Studio 또는 Visual Studio 데이터 전송을 가져와 대상 스키마를 변경하는 데 몇 시간을 보냈습니다. 내가 원하는 방식으로 물건을 얻기 위해 새 서버에 덤프하십시오.
이 게시물에 설명 된대로 여러 데이터베이스 개체의 스키마를 일괄 적으로 변경할 수 있습니다.
SQL Server를 SA 계정으로 열고 아래 쿼리를 지나서 새 쿼리를 클릭하십시오.
그런 다음 실행을 클릭하면 소유 한 모든 스키마를 SA 계정으로 롤백합니다.
alter authorization on schema::[db_datareader] to [dbo]
alter authorization on schema::[db_datareader] to [db_datareader]
alter authorization on schema::[db_datawriter] to [dbo]
alter authorization on schema::[db_datawriter] to [db_datawriter]
alter authorization on schema::[db_securityadmin] to [dbo]
alter authorization on schema::[db_securityadmin] to [db_securityadmin]
alter authorization on schema::[db_accessadmin] to [dbo]
alter authorization on schema::[db_accessadmin] to [db_accessadmin]
alter authorization on schema::[db_backupoperator] to [dbo]
alter authorization on schema::[db_backupoperator] to [db_backupoperator]
alter authorization on schema::[db_ddladmin] to [dbo]
alter authorization on schema::[db_ddladmin] to [db_ddladmin]
alter authorization on schema::[db_owner] to [dbo]
alter authorization on schema::[db_owner] to [db_owner]
ms-help : //MS.SQLCC.v9/MS.SQLSVR.v9.en/tsqlref9/html/0a760138-460e-410a-a3c1-d60af03bf2ed.htm
ALTER SCHEMA schema_name TRANSFER securable_name