C#连接Oracle数据库字符串(引入DLL)

Posted chenyanbin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#连接Oracle数据库字符串(引入DLL)相关的知识,希望对你有一定的参考价值。

需求:从一台Oracle数据库获取数据,本以为是很简单的事情,直接将原来的SqlClient换成OracleClient调用,结果远没自己想的简单。要么安装Oracle客户端,要么安装PLSQL。网上这方面搜索后,太多的文章,还要不停的去测试。最后找个引入外部类库的方式。这个DLL其实是Oracle为C#专门提供的,在它的官方也可以下载到(不过找起来很麻烦)。

这里我就把这个方案和dll分享给大家。

链接:https://pan.baidu.com/s/17saKNnBVyDvMbt1L8lSf6A
提取码:sr97

DEMO示例

using Oracle.ManagedDataAccess.Client; //引入命名空间

        private void button1_Click(object sender, EventArgs e)
        
            string strSql = "select * from s_user";
            DataTable dt = QueryDt(strSql);
        
//Oracle连接字符串
private static string strconn = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=172.30.0.37)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=EMES)));Persist Security Info=True;User ID=EMES_DEV;Password=EMES_DEV;";

        private DataTable QueryDt(string sql)
        
            using (OracleConnection conn = new OracleConnection(strconn))
            
                try
                
                    if (conn.State != ConnectionState.Open)
                    
                        conn.Open();
                    
                    OracleDataAdapter adap = new OracleDataAdapter(sql, conn);
                    DataTable dt = new DataTable();
                    adap.Fill(dt);
                    return dt;
                
                catch (Exception ex)
                
                    return null;
                
                finally
                
                    conn.Close();
                
            
        

连接字符串格式:

1 格式:
2 string strconn = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=172.30.0.37)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=EMES)));Persist Security Info=True;User ID=EMES_DEV;Password=EMES_DEV;";
3 
4 格式:
5 string strconn = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=远程服务器IP地址)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=远程服务器数据库服务名称)));Persist Security Info=True;User ID=数据库用户名;Password=数据库密码;";

远程服务器数据库服务名称如下:

技术图片

效果:

 技术图片

 

以上是关于C#连接Oracle数据库字符串(引入DLL)的主要内容,如果未能解决你的问题,请参考以下文章

Oracle.ManagedDataAccess.dll

c#如何将数据库连接封装成dll

C#连接Oracle的时候,Oracle.DataAccess.dll能连接数据库,Oracle.ManagedDataAccess却不能?

C#中连接MySql的字符串

C#连接oracle连接字符串怎么写啊?

Navicat 连接oracle数据库问题