硬件环境:Win10 64位+ VS2015 + ODP.Net for VS2015
配置ODP.Net
首先下载 ,下载此文件需要注册Oracle社区账号并接受相关的协议,此文件提供了以下组件:
- Oracle Developer Tools for Visual Studio 12.1.0.2.4 下载次文件
- Oracle Data Provider for .NET 4 12.1.0.2.0
- Oracle Providers for ASP.NET 4 12.1.0.2.0
下载完成后运行MSI安装程序进行安装,安装完成后会自动注册VS2015的相关插件,重新启动VS2015后将会看到Oracle的相关命令,比如SQL *PLUS支持等。同时添加数据库时也能看到相应的选项。
ODP.Net支持所有Oracle版本,因此下载时只需要注意VS的版本即可。
配置tnsnames.ora
ODP.Net默认使用安装目录下的 tnsnames.ora
,若安装目录在Program Files下,可能会遇到无权限等问题,此时使用管理员权限打开命令行,切换到对应目录并使用notepad编辑。
复制服务器端的tnsnames.ora文件内容,或者自己手动编辑,格式如下:
<数据源别名> = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = <主机名或ip> )(PORT = <端口号> )) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = <数据库服务名> ) ) ) 数据库服务名> 端口号> 主机名或ip> 数据源别名>
添加数据库
打开 工具 - 连接到数据库
,数据源修改为 Oracle数据库
下的 ODP.NET,托管驱动程序
,然后点击 确定
,打开 添加连接
窗口。
填写用户名,密码并选择数据源,然后测试连接,成功的话说明已经连通,点击确定即可。
连接数据库并使用
连接数据库
string Str_oracon = "USER ID = MONKEY;Password=123456;Data Source=ORCL";OracleConnection myCon = new OracleConnection(Str_oracon);conn.Open()myconn.Open();String sql = "select * from IDIOMS i where i.name like '" + str2 + "%'";OracleCommand cmd = new OracleCommand(sql, myconn);cmd.CommandType = CommandType.Text;OracleDataReader dr = cmd.ExecuteReader(); // C#dr.Read();rusult.Text = dr["name"].ToString(); // C# 将单个查询结果返回到label标签myconn.Close();
常见错误
column not allowed here
数据类型不符,检查对应项目数据类型是否正确。
missing comma
命令格式不对,检查一下自己的SQL命令是否有错误,特别是在有字符串的时候,需要使用 ""
来代表一个字符串中的 "
。
identifier is too long
标识符过长(不得超过30字符),不是非常明白原因,不过我取消掉insert命令中指定位置的部分之后,这个错误消失了。
missing INTO keyword
缺少into关键字(手滑打成了inte),检查一下自己的SQL命令是否有错误。
参考内容: