Recently we
evaluated entity framework, we use oracle as a database on most of our
projects. The default EF provider is for SqlServer. We have searched for an
oracle provider. There is a provider directly from Oracle (ODP.NET provider),
this has limited database support (oracle 9 is not supported anymore), and
offers only database first and model first approach. Code first is not
officially supported. An alternative to ODP.NET is a commercial provider from
devart – devart dotconnect for Oracle. This has support for older databases and
for code first and the latest EF (EF 6) too.
After you
buy a licence you can install the provider to your development machine. All the
devart assemblies are installed to GAC. The first thing I did was to copy the
assemblies to a versioned local LIB folder and reference the assemblies from
there. This way you know what you are referencing. GAC causes several problems
in deployment, assemblies referenced from GAC are not deployed during build
process, you need to manually set Copy Local to true on every assembly. You
need to do it even if you reference it from a LIB, but you are on a machine
(Development manchine)which has it in a GAC, it won’t be copied to output
without setting copy local to true. Another thing are indirect references, a
client application references an assembly which has reference to devart
assemblies, they are not copied to output when deploying the client application
even if you set copy local to true, you
need to reference Devart directly from the client application and set copy
local to true on every assembly you reference. This is not related to
Devart, this works the same way on every assembly from GAC I think.
The key
assemblies for entity framework support are:
Devart.Data
Devart.Data.Oracle
Devart.Data.Oracle.Entity
Next, you
need to tell entity framework that there is a devart entity framework provider
for oracle.
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory,
EntityFramework">
<parameters>
<parameter
value="v11.0"
/>
</parameters>
</defaultConnectionFactory>
<providers>
<provider
invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices,
EntityFramework.SqlServer" />
<provider invariantName="Devart.Data.Oracle" type="Devart.Data.Oracle.Entity.OracleEntityProviderServices,
Devart.Data.Oracle.Entity, Version=8.2.90.6, Culture=neutral,
PublicKeyToken=09af7300eec23701" />
</providers>
</entityFramework>
<system.data>
<DbProviderFactories>
<remove invariant="Devart.Data.Oracle" />
<add name="dotConnect for Oracle" invariant="Devart.Data.Oracle"
description="Devart dotConnect for Oracle"
type="Devart.Data.Oracle.OracleProviderFactory,
Devart.Data.Oracle,
Version=8.2.90.0, Culture=neutral, PublicKeyToken=09af7300eec23701" />
</DbProviderFactories>
</system.data>
And finally
the connection string for the db context is:
<connectionStrings>
<add name="OnlineDataDbContextConnectionString" connectionString="User Id=*;Password=*;Server=*;Home=oraclient11g_home1;Persist
Security Info=True;" providerName="Devart.Data.Oracle"/>
</connectionStrings>
There is an
interesting note about the connection string, the Home property. This property
is not a standard property (at least not in System.Data.OracleClient which we
used before Devart). Home property specifies which oracle home to use when
connecting to database. You can have multiple versions of oracle client
installed on your computer (with multiple oracle homes), Devart gives you a
possibility to choose the right oracle home.
System.Data.OracleClient is an oracle driver written by Microsoft (and
currently is deprecated), and it is not using this Home property. It simply
uses the first oracle home which it finds on the computer (particularly it
scans the PATH environment variable, and takes the first path to oracle home
from there). Devart forces you to explicitly name the oracle home. This could
be tricky if your oracle homes are named differently on the development
machines,or build servers or production machines. Be sure that on every machine
the same name for oracle home is used.
This makes
devart entity framework oracle provider work on the machine where you installed
the devart package (assemblies in GAC and licence information set). You need to
do additional setup when deploying to a different machine (where you don’t want
to install devart), referencing the devart assemblies from client and set their
copy local attribute to true as we mentioned above and another extra step is to
generate licence information to assemblies which are using devart. If you omit
this, Devart will complain on that machine and say it is not licenced.
How devart
licencing works in general is available here: http://www.devart.com/dotconnect/mysql/docs/Licensing.html
The easiest
way to make licencing work is from Visual Studio, choose the licencnig menu
item as shown on the picture below:
All the
available assemblies are listed and an UI is provided to fix the problems –
generate licencing information. Just follow the wizard and you assemblies will
be able to use devart on different machine too.
In next
blog post I’ll show you how to get rid of System.Data.OracleClient for classic
AdoNET access and use devart instead.