Al momento sei offline in attesa che la connessione Internet venga ristabilita

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"

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
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: Per informazioni sulle ultime modifiche apportate nella funzionalità del motore di database in SQL Server 2008, visitare il seguente sito Microsoft TechNet Web:
"SQL Server 2008 Database Engine" sqlserver2008 sqlserver2k8 sqlsvr2008 sqlsvr2k8 SQL2008RelNoteDatabaseEngine

Avviso: questo articolo è stato tradotto automaticamente

Proprietà

ID articolo: 955629 - Ultima revisione: 03/19/2009 22:27:18 - Revisione: 2.1

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

  • kbmt sql2008relnotedatabaseengine sql2008relnote kbprogramming kbautomation kberrmsg kbtshoot kbexpertiseinter kbprb KB955629 KbMtit
Feedback
html>ent.createElement('meta');m.name='ms.dqp0';m.content='true';document.getElementsByTagName('head')[0].appendChild(m);" onload="var m=document.createElement('meta');m.name='ms.dqp0';m.content='false';document.getElementsByTagName('head')[0].appendChild(m);" src="http://c1.microsoft.com/c.gif?"> >