Pergunta

Estamos tentando construir uma EntityConnection dinamicamente de modo que diferentes usuários estão se conectando ao differnet bancos de dados determinada em tempo de execução.Para fazer isto, estamos testando o código encontrado aqui: http://msdn.microsoft.com/en-us/library/bb738533.aspx.Temos implementado esta abaixo:

' 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

Quando o conn.Open() é executado um erro é gerado:"Não é possível carregar o especificado recurso de metadados." Isso parece indicar que um ou mais dos "res://*..." referências é errado.Eu já confirmou que o projeto, de fato, contêm esses arquivos (sob o bin/debug pasta).O que está faltando aqui - alguma idéia?

Obrigado

Foi útil?

Solução

Sim, o res:// parte é errado.Olhar para os nomes de recursos no Reflector (dentro do conjunto), e não em seu sistema de arquivos local, para ver o que deve ser.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top