zoukankan      html  css  js  c++  java
  • C# 连接 Oracle 的几种方式

    一:通过System.Data.OracleClient(需要安装Oracle客户端并配置tnsnames.ora)
    1. 添加命名空间System.Data.OracleClient引用
    2. using System.Data.OracleClient;
    3. 
    string connString = "User ID=IFSAPP;Password=IFSAPP;Data Source=RACE;";
    OracleConnection conn = new OracleConnection(connString);
    try
    {
        conn.Open();
        MessageBox.Show(conn.State.ToString());
    }
    catch (Exception ex)
    {
        ShowErrorMessage(ex.Message.ToString());
    }
    finally
    {
        conn.Close();
    }

    二:通过System.Data.OracleClient(需要安装Oracle客户端不需配置tnsnames.ora)
    1. 添加命名空间System.Data.OracleClient引用
    2. using System.Data.OracleClient;
    3.
    string connString = "User ID=IFSAPP;Password=IFSAPP;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = RACE)))";
    OracleConnection conn = new OracleConnection(connString);
    try
    {
        conn.Open();
        MessageBox.Show(conn.State.ToString());
    }
    catch (Exception ex)
    {
        ShowErrorMessage(ex.Message.ToString());
    }
    finally
    {
        conn.Close();
    }

    三:通过System.Data.OleDb和Oracle公司的驱动
    1. 添加命名空间System.Data.OracleClient引用
    2. using System.Data.OleDb;
    3.
    string connString = "Provider=OraOLEDB.Oracle.1;User ID=IFSAPP;Password=IFSAPP;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = RACE)))";
    OleDbConnection conn = new OleDbConnection(connString);
    try
    {
        conn.Open();
        MessageBox.Show(conn.State.ToString());
    }
    catch (Exception ex)
    {
        ShowErrorMessage(ex.Message.ToString());
    }
    finally
    {
        conn.Close();
    }

    四:通过System.Data.OleDb和微软公司的Oracle驱动
    1. 添加命名空间System.Data.OracleClient引用
    2. using System.Data.OleDb;
    3.
    string connString = "Provider=MSDAORA.1;User ID=IFSAPP;Password=IFSAPP;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = RACE)))";
    OleDbConnection cnn = new OleDbConnection(connString);
    try
    {
        conn.Open();
        MessageBox.Show(conn.State.ToString());
    }
    catch (Exception ex)
    {
        ShowErrorMessage(ex.Message.ToString());
    }
    finally
    {
        conn.Close();
    }

    备注:
    a.XP操作系统已经安装了微软公司的Oracle驱动C:Program FilesCommon FilesSystemOle DBmsdaora.dll
    b.该驱动需要Oracle客户端的三个文件(oraocixe10.dll、oci.dll、ociw32.dll)放在System32下即可

    五:使用ODP连接
    1. 下载安装ODP.NET(http://www.oracle.com/technetwork/developer-tools/visual-studio/downloads/index.html)
    2. 安装完全成后会产生一序列文件。
    3. 找到这个安装目录,打开文件夹%ORACLE_HOME%NetworkAdmin在这个下面建立一个tnsnames.ora的文件,其内容可以参考其下的Sample目录下面的配置
    Oracle.RACE =
    (DESCRIPTION=
       (ADDRESS_LIST=
         (ADDRESS=
           (PROTOCOL=TCP)
           (HOST=127.0.0.1)
           (PORT=1521)
         )
       )
       (CONNECT_DATA=
         (SID=RACE)
         (SERVER=DEDICATED)
       )
    )
    Oracle.RACE为连接字符串名称,可以随便取。等号后面的字符串可以在Enterprise Manager Console工具中连接数据库后的TNS描述符中拷过来
    4. 引用Oracle.DataAccess命名空间
    5. using Oracle.DataAccess.Client;
    6. 示例代码:
    string connString = "DATA SOURCE=Oracle.RACE;PERSIST SECURITY INFO=True;USER ID=IFSAPP;password=IFSAPP";
    OracleConnection conn = new OracleConnection(connString);
    try
    {
        conn.Open();
        OracleCommand cmd = new OracleCommand(cmdText,conn);
        OracleDataReader reader = cmd.ExecuteReader();
        this.DataGridView1.DataSource = reader;
        this.DataGridView1.DataBind();
    }
    catch (Exception ex)
    {
        ShowErrorMessage(ex.Message.ToString());
    }
    finally
    {
        conn.Close();
    }

    六:使用第三方驱动
    第三方驱动有 Devart,下载驱动 http://www.devart.com/dotconnect/oracle/,但是是商业版,需要购买许可或破解
    连接格式 User ID=myUsername;Password=myPassword;Host=ora;Pooling=true;Min Pool Size=0;Max Pool Size=100;Connection Lifetime=0;
    1. 引用Devart.Data.Oracle命名空间
    2. using Devart.Data.Oracle;
    3.
    OracleConnection conn = new OracleConnection();
    conn.ConnectionString = "";
    conn.Unicode = true;
    conn.UserId = "IFSAPP";
    conn.Password = "IFSAPP";
    conn.Port = 1521;
    conn.Server = "127.0.0.1";
    conn.Sid = "RACE";
    try
    {
        conn.Open();
        //execute queries, etc
    }
    catch (Exception ex)
    {
        ShowErrorMessage(ex.Message.ToString());
    }
    finally
    {
        conn.Close();
    }

  • 相关阅读:
    【LeetCode】048. Rotate Image
    【LeetCode】036. Valid Sudoku
    【LeetCode】060. Permutation Sequence
    【LeetCode】001. Two Sum
    【LeetCode】128. Longest Consecutive Sequence
    【LeetCode】081. Search in Rotated Sorted Array II
    【LeetCode】033. Search in Rotated Sorted Array
    顺时针打印矩阵
    矩形覆盖
    二维数组中的查找
  • 原文地址:https://www.cnblogs.com/jliuwork/p/4164425.html
Copyright © 2011-2022 走看看