Messaggio di errore quando si esegue un'applicazione, script o di funzionalitÓ da un'installazione precedente di SQL Server che utilizza common language runtime funzionalitÓ in SQL Server 2008 o in SQL Server 2008 R2: "si Ŕ verificato un errore di .NET Framework"

Traduzione articoli Traduzione articoli
Identificativo articolo: 955629 - Visualizza i prodotti a cui si riferisce l?articolo.
Espandi tutto | Chiudi tutto

In questa pagina

Sintomi

Dopo l'aggiornamento a Microsoft SQL Server 2008 o a Microsoft SQL Server 2008 R2 quando si esegue un'applicazione, uno script o una funzionalitÓ da un'installazione precedente di Microsoft SQL Server utilizza le funzionalitÓ di common language runtime (CLR), viene visualizzato un messaggio di errore analogo al seguente:
Msg 6522, livello 16, stato 1, riga 1

Errore di .NET Framework durante l'esecuzione di routine definite dall'utente o routine name aggregazione:

System.InvalidOperationException: Accesso ai dati non Ŕ consentito in questo contesto. Il contesto Ŕ una funzione o metodo non contrassegnato con DataAccessKind.Read o SystemDataAccessKind.Read, Ŕ un callback per ottenere i dati dal metodo FillRow di una funzione valutata a livello di tabella o Ŕ un metodo di convalida UDT.

System.InvalidOperationException
Ad esempio, questo problema pu˛ verificarsi nei seguenti scenari.

Scenario 1

Si utilizza un metodo che presenta le seguenti caratteristiche:
  • Il metodo utilizza una funzione CLR definita dall'utente, un metodo di tipo definito dall'utente (UDT) o un aggregato definito dall'utente che esegue la rappresentazione.
  • Il metodo utilizza un oggetto di grandi dimensioni (LOB) come parametro.
  • Il metodo non utilizza la proprietÓ DataAccesKind.Read sul metodo.

Scenario 2

╚ possibile utilizzare il metodo INIT in una funzione valutata a livello di tabella CLR esegue la rappresentazione.

Scenario 3

╚ possibile utilizzare il metodo FillRow di una funzione valutata a livello di tabella CLR esegue la rappresentazione.

Cause

Questo problema si verifica a causa di una modifica nella funzionalitÓ del motore di database in SQL Server 2008 e in SQL Server 2008 R2.

Workaround

Per aggirare il problema come descritto negli scenari nella sezione "Sintomi", utilizzare uno dei metodi descritti di seguito.

Metodo 1: Per risolvere il problema nello scenario 1 e nel secondo scenario

Per aggirare questo problema, aggiungere la proprietÓ DataAccessKind.Read al metodo.

Metodo 2: Per risolvere il problema nello scenario 3

Per aggirare questo problema, effettuare le seguenti operazioni:
  • Rimuovere la rappresentazione dal metodo FillRow.
  • Non accedono alle risorse esterne utilizzando il metodo FillRow.
  • Accedere alle risorse esterne solo mediante il metodo INIT della funzione valutata a livello di tabella.

Riferimenti

Per informazioni sulla proprietÓ DataAccessKind.Read e altri attributi personalizzati per la routine CLR, visitare il seguente sito Microsoft TechNet Web:
http://technet.microsoft.com/en-us/library/ms131050.aspx
Per informazioni sulle ultime modifiche apportate nella funzionalitÓ del motore di database in SQL Server 2008, visitare il seguente sito Microsoft TechNet Web:
http://technet.microsoft.com/en-us/library/ms143179(SQL.100).aspx

ProprietÓ

Identificativo articolo: 955629 - Ultima modifica: giovedý 19 marzo 2009 - Revisione: 2.1
Le informazioni in questo articolo si applicano a:
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Express
  • Microsoft SQL Server 2008 Express with Advanced Services
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Workgroup
  • Microsoft SQL Server 2008 R2 Datacenter
  • Microsoft SQL Server 2008 R2 Developer
  • Microsoft SQL Server 2008 R2 Enterprise
  • Microsoft SQL Server 2008 R2 Express
  • Microsoft SQL Server 2008 R2 Express with Advanced Services
  • Microsoft SQL Server 2008 R2 Standard
  • Microsoft SQL Server 2008 R2 Standard Edition for Small Business
  • Microsoft SQL Server 2008 R2 Workgroup
Chiavi:á
kbmt sql2008relnotedatabaseengine sql2008relnote kbprogramming kbautomation kberrmsg kbtshoot kbexpertiseinter kbprb KB955629 KbMtit
Traduzione automatica articoli
Il presente articolo Ŕ stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell?utente. Tuttavia, un articolo tradotto in modo automatico non Ŕ sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, pi¨ o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non Ŕ la sua. Microsoft non Ŕ responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell?utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.
Clicca qui per visualizzare la versione originale in inglese dell?articolo: 955629
LE INFORMAZIONI CONTENUTE NELLA MICROSOFT KNOWLEDGE BASE SONO FORNITE SENZA GARANZIA DI ALCUN TIPO, IMPLICITA OD ESPLICITA, COMPRESA QUELLA RIGUARDO ALLA COMMERCIALIZZAZIONE E/O COMPATIBILITA' IN IMPIEGHI PARTICOLARI. L'UTENTE SI ASSUME L'INTERA RESPONSABILITA' PER L'UTILIZZO DI QUESTE INFORMAZIONI. IN NESSUN CASO MICROSOFT CORPORATION E I SUOI FORNITORI SI RENDONO RESPONSABILI PER DANNI DIRETTI, INDIRETTI O ACCIDENTALI CHE POSSANO PROVOCARE PERDITA DI DENARO O DI DATI, ANCHE SE MICROSOFT O I SUOI FORNITORI FOSSERO STATI AVVISATI. IL DOCUMENTO PUO' ESSERE COPIATO E DISTRIBUITO ALLE SEGUENTI CONDIZIONI: 1) IL TESTO DEVE ESSERE COPIATO INTEGRALMENTE E TUTTE LE PAGINE DEVONO ESSERE INCLUSE. 2) I PROGRAMMI SE PRESENTI, DEVONO ESSERE COPIATI SENZA MODIFICHE, 3) IL DOCUMENTO DEVE ESSERE DISTRIBUITO INTERAMENTE IN OGNI SUA PARTE. 4) IL DOCUMENTO NON PUO' ESSERE DISTRIBUITO A SCOPO DI LUCRO.

Invia suggerimenti

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com