Eliminazione di un assembly
Gli assembly registrati in SQL Server utilizzando l'istruzione CREATE ASSEMBLY possono essere eliminati quando la funzionalità che forniscono non è più necessaria. L'eliminazione di un assembly ne comporta la rimozione insieme a tutti i file associati, ad esempio i file di debug, dal database. Per eliminare un assembly, utilizzare l'istruzione DROP ASSEMBLY con la sintassi seguente:
DROP ASSEMBLY MyDotNETAssembly
DROP ASSEMBLY non interferisce con il codice che fa riferimento all'assembly attualmente in esecuzione. Tuttavia, dopo l'esecuzione di DROP ASSEMBLY qualsiasi tentativo di richiamare il codice dell'assembly avrà esito negativo.
DROP ASSEMBLY restituisce un errore se all'assembly viene fatto riferimento da un altro assembly esistente nel database oppure se viene utilizzato da funzioni CLR (Common Language Runtime), procedure, trigger, tipi definiti dall'utente o funzioni di aggregazione definite dall'utente nel database corrente. Utilizzare innanzitutto le istruzioni DROP AGGREGATE, DROP FUNCTION, DROP PROCEDURE, DROP TRIGGER e DROP TYPE per eliminare gli oggetti di database gestiti contenuti nell'assembly.
Rimozione di un tipo definito dall'utente dal database
L'istruzione DROP TYPE rimuove un tipo definito dall'utente dal database corrente. Dopo aver eliminato un tipo definito dall'utente, è possibile utilizzare l'istruzione DROP ASSEMBLY per eliminare l'assembly dal database.
L'istruzione DROP TYPE non riesce se gli oggetti dipendono dal tipo definito dall'utente, come nelle situazioni seguenti:
Tabelle del database che contengono colonne definite utilizzando il tipo definito dall'utente.
Funzioni, stored procedure o trigger che utilizzano variabili o parametri del tipo definito dall'utente, creati nel database con la clausola WITH SCHEMABINDING.
Ricerca di dipendenze di tipi definiti dall'utente
È necessario innanzitutto eliminare tutti gli oggetti dipendenti, quindi eseguire l'istruzione DROP TYPE. La query Transact-SQL seguente consente di individuare tutte le colonne e i parametri che utilizzano un tipo definito dall'utente (UDT) nel database di AdventureWorks2008R2.
USE Adventureworks2008R2;
SELECT o.name AS major_name, o.type_desc AS major_type_desc
, c.name AS minor_name, c.type_desc AS minor_type_desc
, at.assembly_class
FROM (
SELECT object_id, name, user_type_id, 'SQL_COLUMN' AS type_desc
FROM sys.columns
UNION ALL
SELECT object_id, name, user_type_id, 'SQL_PROCEDURE_PARAMETER'
FROM sys.parameters
) AS c;
JOIN sys.objects AS o
ON o.object_id = c.object_id;
JOIN sys.assembly_types AS at
ON at.user_type_id = c.user_type_id;