Condividi tramite


Separazione tra schema e utente

Il comportamento degli schemi in SQL Server 2005 è cambiato. Gli schemi non equivalgono più agli utenti del database; ogni schema è ora uno spazio dei nomi distinto e indipendente dal database dell'utente che lo ha creato. In altre parole, uno schema è semplicemente un contenitore di oggetti. Lo schema può essere di proprietà di qualsiasi utente e la sua proprietà è trasferibile.

Nuovo comportamento

La separazione della proprietà dagli schemi ha implicazioni importanti:

  • La proprietà degli schemi e delle entità a protezione diretta definite a livello di ambito dello schema è trasferibile. Per ulteriori informazioni, vedere ALTER AUTHORIZATION (Transact-SQL).

  • È possibile spostare gli oggetti tra gli schemi. Per ulteriori informazioni, vedere ALTER SCHEMA (Transact-SQL).

  • Un singolo schema può contenere oggetti di proprietà di più utenti del database.

  • Più utenti del database possono condividere un singolo schema predefinito.

  • Le autorizzazioni per schemi ed entità a protezione diretta contenute negli schemi possono essere gestite con una maggiore precisione rispetto alle versioni precedenti. Per ulteriori informazioni, vedere GRANT (autorizzazioni per schemi) (Transact-SQL) e GRANT - autorizzazioni per oggetti (Transact-SQL).

  • Uno schema può essere di proprietà di qualsiasi entità di database, inclusi i ruoli e i ruoli applicazione.

  • È possibile eliminare un utente del database senza rimuovere gli oggetti in uno schema corrispondente.

  • Il codice scritto per le versioni precedenti di SQL Server può restituire risultati non corretti, se in esso si presuppone che gli schemi siano equivalenti agli utenti del database.

  • Le viste del catalogo progettate per versioni precedenti di SQL Server, inclusa la vista sysobjects, possono restituire risultati non corretti.

A partire da SQL Server 2005, gli schemi sono entità esplicite riflesse nei metadati; di conseguenza, gli schemi possono avere un solo proprietario, ma un singolo utente può possedere molti schemi. Poiché questa relazione complessa non è riflessa nelle tabelle di sistema di SQL Server 2000, in SQL Server 2005 sono state introdotte nuove viste del catalogo, che rispecchiano i nuovi metadati in modo accurato.

Nella tabella seguente è indicato il mapping tra le tabelle di sistema di SQL Server 2000 e le viste equivalenti del catalogo di SQL Server 2005 e versioni successive.

Tabella di sistema di SQL Server 2000

Vista del catalogo di SQL Server 2005 e versioni successive

sysusers

sys.database_principals

sys.schemas

syslogins

sys.server_principals

SQL Server 2005 presentano più di 250 nuove viste del catalogo. È consigliabile utilizzare le nuove viste del catalogo per accedere ai metadati. Per ulteriori informazioni, vedere Viste del catalogo (Transact-SQL).

Le nuove istruzioni DDL (Data Definition Language) possono introdurre complessità nei metadati di sistema che non vengono riflesse in modo accurato nelle viste di catalogo precedenti, ad esempio sysobjects. In questo esempio l'ID utente e il nome dello schema restituiti da sysobjects non sono sincronizzati e non riflettono la distinzione tra utente e schema introdotta con SQL Server 2005.

use tempdb
go
create login u1 with password = 'Mdfjd$sakj943857l7sdfh##30'
create user u1 with default_schema = u1
go
grant create table to u1 
go
create schema sch1
go
create schema u1 authorization u1
go
execute as user = 'u1'
go
create table t1(c1 int)
go
revert
go
select user_name(uid) , * from sysobjects where name = 't1'
go
Nota di attenzioneAttenzione

È necessario utilizzare le nuove viste del catalogo in tutti i database in cui sono state applicate in qualsiasi momento una o più delle istruzioni DDL seguenti: CREATE/ALTER/DROP SCHEMA, CREATE/ALTER/DROP USER, CREATE/ALTER/DROP ROLE, CREATE/ALTER/DROP APPROLE, ALTER AUTHORIZATION.

Schemi predefiniti

Per risolvere i nomi delle entità a protezione diretta non completi, in SQL Server 2000 viene utilizzata la risoluzione dei nomi per controllare lo schema di proprietà dell'utente del database che ha eseguito la chiamata e lo schema di proprietà di dbo.

A partire da SQL Server 2005, ogni utente dispone di un schema predefinito. che può essere impostato e modificato tramite l'opzione DEFAULT_SCHEMA di CREATE USER o ALTER USER. Se DEFAULT_SCHEMA non viene definito, l'utente del database disporrà dello schema dbo come schema predefinito.