Από τον 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