sqlschool.gr logo

articles

Articles of SQLschool.gr Team

Move object(s) to another schema

Antonios Chatzipavlis
Thursday 28 January 2021

Από τον SQL Server 2005 έχουμε την ξεκάθαρη δυνατότητα χρήσης των schemas που μας δίνουν πολλές δυνατότητες με κυρίαρχη αυτή του security granularity (ΙΜΗΟ).

Η ένταξη ενός object (table, view, sp, function κλπ.) σε ένα schema γίνεται κατά την δημιουργία αυτού βάζοντας μπροστά από το object name το schema name.

Αν μετά από την δημιουργία του object επιθυμεί κάποιος να μεταφέρει αυτό σε άλλο schema μια λύση είναι να το σβήσει και να το δημιουργήσει ξανά στο schema που επιθυμεί.

Αυτό δεν είναι το καλύτερο διότι αν το object είναι table που περιέχει δεδομένα αυτό σημαίνει ότι πρέπει να δημιουργηθεί διαδικασία τέτοια που να διασφαλίζει την μη απώλεια δεδομένων.

Πρακτικά όμως δεν χρειάζεται καθώς μπορεί να γίνει με ευκολότερο και συντομότερο τρόπο και αυτό είναι η χρήση της

SQL Script

ALTER SCHEMA <destination_schema> TRANSFER <orginal_schema_name>.<original_object_name>

Αν κάποιος τώρα έχει πολλά objects που πρέπει να μεταφέρει, το παρακάτω script δημιουργεί τα απαιτούμενα ALTER SCHEMA statements χρησιμοποιώντας το sys.objects και τα κατάλληλα κριτήρια για τον εντοπισμό αυτών που θέλει. Στο script για παράδειγμα ζητάω μόνο τα tables.

SQL Script

declare        @crlf           char(2) = char(13)+char(10);
declare        @tab            char(1) = char(9);
declare        @scriptout      varchar(max)='';
declare        @dest_schema    varchar(20)='dbo';

select    @scriptout +='ALTER SCHEMA ' + QUOTENAME(@dest_schema) 
                     + ' TRANSFER '+ QUOTENAME(SCHEMA_NAME(schema_id)) 
                     + '.' + QUOTENAME(name) +';' + @crlf
from    sys.objects
where    type='U'
        and
        schema_id <> SCHEMA_ID(@dest_schema);


-- script final output
select @scriptout FOR XML PATH(''); 

//Antonios Chatzipavlis


Antonios Chatzipavlis

Antonios Chatzipavlis

Antonios Chatzipavlis is a highly experienced Data Solutions Consultant and Trainer. He has been working in the IT industry since 1988, holding various roles such as senior developer, IT Manager, Data & AI Solutions Architect and Consultant.

Since 1995, Antonios has focused on modern technologies and software development tools, primarily by Microsoft. He has specialized in Data & AI since 2000, with expertise in Microsoft Data Platform (SQL Server, Azure SQL Databases, Azure Synapse Analytics, Microsoft Fabric, Power BI, AI) and Databricks.

Antonios is also a Microsoft Certified Trainer (MCT) for over 25 years, has been recognized as a Microsoft Most Valuable Professional (MVP) in Data Platform since 2010 and he is in the Data Expert 40 Powerlist 2024 by Boussias. He is the co-founder and visionary behind XLYTiCA, a company dedicated to Data & AI solutions.

Episode

Task Flows in Microsoft Fabric

image

More Episodes...

Tip

What's New in SQL Server 2022 - Episodes

More Tips...

Become a member

If you want to receive updates from us become a member to our community.

Connect

Explore

Learn


sqlschool.gr © 2010-2025 All rights reserved

This site uses cookies for operational and analytics purposes only. By continuing to browse this site, you agree to their use.