Condividi tramite


Stringhe di connessione in ADO.NET Entity Framework

Una stringa di connessione contiene informazioni di inizializzazione che vengono passate come parametro da un provider di dati a un'origine dati. La sintassi dipende dal provider di dati e la stringa di connessione viene analizzata durante il tentativo di aprire una connessione. Le stringhe di connessione usate da Entity Framework contengono informazioni che consentono di connettersi al provider di dati ADO.NET sottostante che supporta Entity Framework, nonché informazioni sui file di modello e di mapping richiesti.

La stringa di connessione viene usata dal provider EntityClient quando si accede ai metadati di modello e di mapping e quando si effettua la connessione all'origine dati. Per impostare o accedere alla stringa di connessione, usare la proprietà ConnectionString di EntityConnection. La classe EntityConnectionStringBuilder può essere usata a livello di codice per costruire o accedere ai parametri nella stringa di connessione.

Gli strumenti di Entity Data Model generano una stringa di connessione che viene archiviata nel file di configurazione dell'applicazione. L'oggetto ObjectContext consente di recuperare automaticamente queste informazioni di connessione quando si creano query di oggetto. È possibile accedere all'oggetto EntityConnection usato da un'istanza di ObjectContext direttamente dalla proprietà Connection.

Sintassi della stringa di connessione

Per informazioni sulla sintassi generale delle stringhe di connessione, vedere Sintassi delle stringhe di connessione| Stringhe di connessione in ADO.NET.

Parametri della stringa di connessione

Nella tabella seguente sono inclusi i nomi validi per i valori di parola chiave nella proprietà ConnectionString.

Parola chiave Descrizione
Provider Obbligatoria se la parola chiave Name non è specificata. Nome del provider usato per recuperare l'oggetto DbProviderFactory per il provider sottostante. Questo valore è costante.

Quando la parola chiave Name non è inclusa in una stringa di connessione di entità, per la parola chiave Provider è necessario specificare un valore non vuoto. Questa parola chiave e la parola chiave Name si escludono a vicenda.
Provider Connection String Facoltativo. Indica la stringa di connessione specifica del provider passata all'origine dati sottostante. Questa stringa di connessione contiene coppie parola chiave/valore valide per il provider di dati. Una parola chiave Provider Connection String non valida produrrà un errore di runtime quando viene valutata dall'origine dati.

Questa parola chiave e la parola chiave Name si escludono a vicenda.

Assicurarsi di eseguire l'escape del valore in base alla sintassi generale delle stringhe di connessione ADO.NET. Si consideri, ad esempio, la stringa di connessione seguente: Server=serverName; User ID = userID. Deve essere preceduto da un carattere di escape in quanto contiene un punto e virgola. Poiché non contiene virgolette doppie, possono essere usate per l'escape:

Provider Connection String ="Server=serverName; User ID = userID";
Metadata Obbligatoria se la parola chiave Name non è specificata. Elenco di percorsi di directory, file e risorse delimitato da barre verticali in cui cercare informazioni relative a metadati e mapping. Di seguito è riportato un esempio:

Metadata=

c:\model | c:\model\sql\mapping.msl;

Gli spazi vuoti a ogni lato del separatore vengono ignorati.

Questa parola chiave e la parola chiave Name si escludono a vicenda.
Name L'applicazione può eventualmente specificare il nome della connessione in un file di configurazione dell'applicazione che fornisce i valori della stringa di connessione parola chiave/valore obbligatori. In questo caso, non è possibile specificare tali valori direttamente nella stringa di connessione. L'utilizzo della parola chiave Name non è consentito in un file di configurazione.

Quando la parola chiave Name non è inclusa nella stringa di connessione, per la parola chiave Provider è necessario specificare valori non vuoti.

Questa parola chiave e tutte le altre parole chiave per la stringa di connessione si escludono a vicenda.

Percorsi dei file di modello e di mapping

Il parametro Metadata contiene un elenco di percorsi in cui il provider EntityClient può eseguire una ricerca di file di modello e di mapping. I file di modello e di mapping spesso sono distribuiti nella stessa directory del file eseguibile dell'applicazione. Tali file possono essere distribuiti anche in un percorso specifico o inclusi come risorse incorporate nell'applicazione.

Le risorse incorporate vengono specificate nel modo seguente:

Metadata=res://<assemblyFullName>/<resourceName>

Per la definizione del percorso di una risorsa incorporata, sono disponibili le opzioni seguenti:

Opzione Descrizione
assemblyFullName Nome completo di un assembly con la risorsa incorporata. Include il nome semplice, il nome della versione, la lingua supportata e la chiave pubblica, nel modo seguente:

ResourceLib, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null

Le risorse possono essere incorporate in qualsiasi assembly accessibile dall'applicazione.

Se si specifica un carattere jolly (*) per assemblyFullName, il runtime di Entity Framework cercherà le risorse nei percorsi seguenti, in questo ordine:

1. L'assembly chiamante.
2. Gli assembly a cui si fa riferimento.
3. Gli assembly nella directory bin di un'applicazione.

Se i file non sono in uno di questi percorsi, verrà generata un'eccezione. Nota: quando si usa un carattere jolly (*), la ricerca di risorse con il nome corretto deve essere eseguita in tutti gli assembly. Per migliorare le prestazioni, specificare il nome dell'assembly anziché il carattere jolly.
resourceName Il nome della risorsa inclusa, ad esempio AdvendtureWorksModel.csdl. I servizi di metadati cercheranno solo i file o le risorse con estensione csdl, ssdl o msl. Se la parola chiave resourceName non è specificata, verranno caricate tutte le risorse dei metadati. Le risorse devono disporre di nomi univoci all'interno di un assembly. Se più file con lo stesso nome sono definiti in directory diverse nell'assembly, la parola chiave resourceName deve includere la struttura di cartelle prima del nome della risorsa, ad esempio NomeCartella.NomeFile.csdl.

resourceName non è obbligatoria quando si specifica un carattere jolly (*) per assemblyFullName.

Nota

Per migliorare le prestazioni, incorporare le risorse nell'assembly chiamante, ad eccezione degli scenari non Web in cui non è presente alcun riferimento ai file di mapping e di metadati sottostanti nell'assembly chiamante.

Nell'esempio seguente vengono caricati tutti i file di modello e di mapping nell'assembly chiamante, gli assembly a cui si fa riferimento e gli altri assembly nella directory bin di un'applicazione.

Metadata=res://*/

Nell'esempio seguente viene caricato il file model.csdl dell'assembly AdventureWorks e vengono caricati i file model.ssdl e model.msl dalla directory predefinita dell'applicazione in esecuzione.

Metadata=res://AdventureWorks, 1.0.0.0, neutral, a14f3033def15840/model.csdl|model.ssdl|model.msl

Nell'esempio seguente sono caricate le tre risorse specificate dall'assembly specifico.

Metadata=res://AdventureWorks, 1.0.0.0, neutral, a14f3033def15840/model.csdl|
res://AdventureWorks, 1.0.0.0, neutral, a14f3033def15840/model.ssdl|
res://AdventureWorks, 1.0.0.0, neutral, a14f3033def15840/model.msl

Nell'esempio seguente sono caricate tutte le risorse incorporate con estensioni csdl, msl e ssdl dall'assembly.

Metadata=res://AdventureWorks, 1.0.0.0, neutral, a14f3033def15840/

Nell'esempio seguente vengono caricate tutte le risorse nel percorso del file relativo, oltre a "datadir\metadata\" dal percorso dell'assembly caricato.

Metadata=datadir\metadata\

Nell'esempio seguente vengono caricate tutte le risorse nel percorso del file relativo provenienti dal percorso dell'assembly caricato.

Metadata=.\

Supporto per la stringa di sostituzione |DataDirectory| e l'operatore radice dell'applicazione Web (~)

DataDirectory e l'operatore ~ vengono usati nella proprietà ConnectionString come parte delle parole chiave Metadata e Provider Connection String. EntityConnection inoltra DataDirectory e l'operatore ~ rispettivamente a MetadataWorkspace e al provider di archiviazione.

Termine Descrizione
&#124;DataDirectory&#124; Si risolve in un percorso relativo di file di mapping e di metadati. Si tratta del valore impostato attraverso il metodo AppDomain.SetData("DataDirectory", objValue). La stringa di sostituzione DataDirectory deve essere circondata dai caratteri pipe e non può essere rappresentata da uno spazio vuoto tra il nome e i caratteri pipe. Il nome DataDirectory non supporta la distinzione tra maiuscole e minuscole.

Se una directory fisica denominata "DataDirectory" deve essere passata come membro dell'elenco di percorsi di metadati, aggiungere uno spazio vuoto su uno o entrambi i lati del nome. Ad esempio: Metadata="DataDirectory1 &#124; DataDirectory &#124; DataDirectory2". Un'applicazione ASP.NET risolve |DataDirectory| nella cartella "<application root>/app_data".
~ Si risolve nella radice dell'applicazione Web. Il carattere ~ in una posizione iniziale viene sempre interpretato come l'operatore radice dell'applicazione Web (~), sebbene possa rappresentare una sottodirectory locale valida. Per fare riferimento a questo tipo di sottodirectory locale, l'utente deve passare in modo esplicito ./~.

DataDirectory e l'operatore ~ devono essere specificati solo all'inizio di un percorso in quanto non vengono risolti in altre posizioni. Entity Framework tenterà di risolvere ~/data, ma considererà /data/~ come un percorso fisico.

Un percorso che inizia con DataDirectory o con l'operatore ~ non può essere risolto in un percorso fisico al di fuori del ramo di DataDirectory e dell'operatore ~. Ad esempio, i percorsi seguenti risolveranno: ~ , ~/data , ~/bin/Model/SqlServer. I percorsi seguenti non riusciranno a risolvere: ~/.., ~/../other.

DataDirectory e l'operatore ~ possono essere estesi per includere sottodirectory, nel modo seguente: |DataDirectory|\Model, ~/bin/Model

La risoluzione della stringa di sostituzione DataDirectory e l'operatore ~ è non ricorsiva. Ad esempio, quando DataDirectory include il carattere ~, si verificherà un'eccezione. In questo modo viene impedita una ricorsione infinita.

Vedi anche