Connectez-vous à la base de données Oracle dans CSharp sans Oracle Client
View more Tutorials:


Ce document est basé sur:
- Visual Studio 2013, 2015
- Oracle 11g, 12c
D'abord, vous devez comprendre le principe de connexion de C# à Database Oracle.
Modèle 1:
Dans ce modèle, sur l'ordinateur qui exécute l'application C#, vous devez installer Oracle Client, c'est une part de l' Oracle qui installe au client pour soutenir de la connexion à database Oracle principale. Si database Oracle est installée dans un ordinateur qui exécute l'application C# , vous ne devez pas installer Oracle Client parce que database Oracle est Oracle Client lui- même. La capacité de Oracle Client est environ 50MB.

Modèle 2:
Le modèle 2 vous permet de connecter directement avec Oracle, sans besoin d'installer Oracle Client sur l'ordinateur qui exécute l'application C#. Vous devez copier quelques bibliothèques DLL d' Oracle client, et quelques bibliothèques ODAC XCopy dans projet.
Parce qu'on n' utilise pas Oracle Client, donc le fichier tnsname.ora ne comprend pas l'information de database Oracle, donc Connection String a besoin de posséder les paramètres précis de database étant comme le contenu du fichier tnsname.ora.
Parce qu'on n' utilise pas Oracle Client, donc le fichier tnsname.ora ne comprend pas l'information de database Oracle, donc Connection String a besoin de posséder les paramètres précis de database étant comme le contenu du fichier tnsname.ora.
// La chaîne de connexion se connecte directement à Oracle.
string connString = "Data Source=(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = "
+ host + ")(PORT = " + port + "))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = "
+ sid + ")));Password=" + password + ";User ID=" + user;




64-bit

32-bit


Les résultats de téléchargement:

Remarque: Vous pouvez utiliser la version 32bit que vous venez de télécharger pour utiliser (même si votre système d'exploitation est 64bit), si vous utilisez la version 64bit parfois l'utilisation C# connecte Oracle, vous receverez une erreur suivante:An unhandled exception of type 'System.BadImageFormatException' occurred in mscorlib.dll Additional information: Could not load file or assembly 'Oracle.DataAccess, Version=4.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342' or one of its dependencies. An attempt was made to load a program with an incorrect format.
Malgré que mon ordinateur utilise le système d'exploitation 64bit, mais j'utilise ODAC 32bit qu'on vient de télécharger dans l'étape précédente.
J'ai créé un projet nommé ConnectOracleWithoutClient:

Le projet est créé.

Compressez le fichier zip que vous venez de télécharger.


Copiez les fichiers suivants:
Directory | File Copy |
<DIR>/instantclient_12_1 | oci.dll |
orannzsbb12.dll | |
oraocci12.dll | |
oraocci12d.dll | |
oraociei12.dll | |
oraons.dll | |
<DIR>/odp.net4/odp.net/bin/4 | Oracle.DataAccess.dll |
<DIR>/oramts/bin | oramts.dll |
oramts12.dll | |
oramtsus.dll | |
<DIR>/odp.net4/bin | OraOps12.dll |
Copiez et collez des fichiers directement dans votre projet dans Visual Studio:

Dans Visual Studio, sélectionnez tous les fichiers DLL et mettez des propriétés pour eux:
- Copy to Output Directory: Copy if newer

Déclarez la bibliothèque, référez à Oracle.DataAccess.dll.




La classe DBOracleUtils a une méthode de l'utilitaire pour connecter directement à Oracle.
DBOracleUtils.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Oracle.DataAccess.Client;
namespace Tutorial.SqlConn
{
class DBOracleUtils
{
public static OracleConnection
GetDBConnection(string host, int port, String sid, String user, String password)
{
Console.WriteLine("Getting Connection ...");
// 'Connection String' se connecte directement à Oracle.
string connString = "Data Source=(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = "
+ host + ")(PORT = " + port + "))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = "
+ sid + ")));Password=" + password + ";User ID=" + user;
OracleConnection conn = new OracleConnection();
conn.ConnectionString = connString;
return conn;
}
}
}
Une classe de l'utilitaireavec des paramètres connecte à votre base de donnée de Oracle:
DBUtils.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Oracle.DataAccess.Client;
namespace Tutorial.SqlConn
{
class DBUtils
{
public static OracleConnection GetDBConnection()
{
string host = "192.168.205.1";
int port = 1521;
string sid = "db12c";
string user = "simplehr";
string password = "12345";
return DBOracleUtils.GetDBConnection(host, port, sid, user, password);
}
}
}
Test Oracle Connection:
Program.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Oracle.DataAccess.Client;
using Tutorial.SqlConn;
namespace ConnectOracleWithoutClient
{
static class Program
{
static void Main(string[] args)
{
//
OracleConnection conn = DBUtils.GetDBConnection();
Console.WriteLine("Get Connection: " + conn);
try
{
conn.Open();
Console.WriteLine(conn.ConnectionString, "Successful Connection");
}
catch (Exception ex)
{
Console.WriteLine("## ERROR: " + ex.Message);
Console.Read();
return;
}
Console.WriteLine("Connection successful!");
Console.Read();
}
}
}
Exécution de l'exemple:

Le prochain tutoriel, vous pouvez voir des instruction sur l'utilisation de Oracle en utilisant C#.