Entity-Framework EntityConnection-Metadatenproblem
-
15-09-2020 - |
Frage
Wir versuchen, eine EntityConnection dynamisch aufzubauen, sodass verschiedene Benutzer eine Verbindung zu verschiedenen, zur Laufzeit bestimmten Datenbanken herstellen.Dazu testen wir den hier gefundenen Code: http://msdn.microsoft.com/en-us/library/bb738533.aspx.Wir haben dies im Folgenden umgesetzt:
' Specify the provider name, server and database.
Dim providerName As String = "System.Data.SqlClient"
Dim serverName As String = "OurDBServerName"
Dim databaseName As String = "OurDBName"
' Initialize the connection string builder for the
' underlying provider.
Dim sqlBuilder As New SqlConnectionStringBuilder
' Set the properties for the data source.
sqlBuilder.DataSource = serverName
sqlBuilder.InitialCatalog = databaseName
sqlBuilder.IntegratedSecurity = False
sqlBuilder.UserID = "OurAppUserName"
sqlBuilder.Password = "OurPassword"
' Build the SqlConnection connection string.
Dim providerString As String = sqlBuilder.ToString
' Initialize the EntityConnectionStringBuilder.
Dim entityBuilder As New EntityConnectionStringBuilder
'Set the provider name.
entityBuilder.Provider = providerName
' Set the provider-specific connection string.
entityBuilder.ProviderConnectionString = providerString
' Set the Metadata location to the current directory.
entityBuilder.Metadata = "res://*/NotaModel.csdl|" & _
"res://*/NotaModel.ssdl|" & _
"res://*/NotaModel.msl"
Console.WriteLine(entityBuilder.ToString)
Using conn As EntityConnection = New EntityConnection(entityBuilder.ToString)
conn.Open()
Console.WriteLine("Just testing the connection.")
conn.Close()
End Using
Wenn conn.Open() ausgeführt wird, wird ein Fehler ausgegeben:"Die angegebene Metadatenressource kann nicht geladen werden." Es scheint anzuzeigen, dass eine oder mehrere der Referenzen "res: //*..." falsch sind.Ich habe bestätigt, dass das Projekt tatsächlich diese Dateien enthält (im Ordner bin/debug).Was fehlt uns hier – irgendwelche Ideen?
Danke
Lösung
Ja das res://
Teil ist falsch.Schauen Sie sich die Ressourcennamen in Reflector (innerhalb der Assembly) und nicht in Ihrem lokalen Dateisystem an, um zu sehen, wie sie lauten sollten.