Is is possible to use a custom .NET data provider without installing it in the GAC?
Can I reference a custom DLL and register it inside my configuration file?
Yes, you can register an implementation of the DbProviderFactory class by adding the following section in your configuration file:
<system.data>
<DbProviderFactories>
<add name="My Custom Data Provider"
invariant="MyCustomDataProvider"
description="Data Provider for My Custom Store"
type="MyNamespace.MyCustomProviderFactory, MyCustomDataProvider, Version=1.0.0.0, Culture=neutral, PublicKeyToken=" />
</DbProviderFactories>
</system.data>
The MyCustomDataProvider
assembly doesn't have to be registered in the GAC but can be deployed together with the application as a private assembly.
You can refer to the registered data provider programmatically by using the value specified in the invariant
attribute. For example you could tell ADO.NET to use the MyNamespace.MyCustomProviderFactory
by specifying MyCustomProvider
as the providerName
in the connection string:
<connectionStrings>
<add name="ConnString"
providerName="MyCustomProvider"
connectionString="MyCustomConnectionString" />
</connectionStrings>
In code you can use the same provider name with the DbProviderFactories.GetFactory method:
DbProviderFactory factory = DbProviderFactories.GetFactory("MyCustomDataProvider");
where factory
will be an instance of the MyNamespace.MyCustomProviderFactory
class.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With