如何快速通过 VS2017连接Oracle12c 数据库
2018-09-15 11:21
645 查看
“一篇VS2017连接Oracle12c心得,最近折腾了一下oracle,写篇小心得,最近课上用Visual Studio2017连接Oracle12c数据库,碰到一个问题,后来发现需要一个第三方开发者工具。”
Visual Studio 2017连接Oracle 12c数据库
开发环境
主机:Win10 + VS2017 + ODP.Net for VS2017 + Oracle 12c
配置ODP.Net
首先下载 Oracle Developer Tools for Visual Studio 2017 ,下载此文件需要注册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
下载完成后,首先
关闭VS,然后运行MSI安装程序进行安装,安装完成后会自动注册VS2017的相关插件,重新启动VS2017后将会看到Oracle的相关命令,比如SQL *PLUS支持等。同时添加数据库时也能看到相应的选项。
ODP.Net支持所有Oracle版本,因此下载时只需要注意VS的版本即可。
配置tnsnames.ora
ODP.Net默认使用安装目录下的
tnsnames.ora,若安装目录在Program Files下,可能会遇到无权限等问题,此时使用管理员权限打开命令行,切换到对应目录并使用notepad编辑。
<数据源别名> = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = <主机名或IP>)(PORT = <端口号>)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = <数据库服务名>) ) )
添加数据库
打开
工具-
连接到数据库,数据源修改为
Oracle数据库下的
ODP.NET,
托管驱动程序,然后点击
确定,打开
添加连接窗口。 填写用户名,密码并选择数据源,然后测试连接,成功的话说明已经连通,点击确定即可。
连接数据库并使用
连接数据库
private static string connectionString = "Password=tiger;User ID=c##scott;Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521)))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=orcl)));"; // private static string connectionString public static DataTable ExecuteReader(String sql) { DataTable dt = new DataTable(); DataSet ds = new DataSet(); OracleConnection connection = new OracleConnection(connectionString); connection.Open(); OracleCommand command = new OracleCommand(sql, connection); OracleDataAdapter sda = new OracleDataAdapter(command); sda.Fill(ds); dt = ds.Tables[0]; sda.Dispose(); ds.Dispose(); connection.Close(); return dt; }
查询数据
成功配置数据源之后,只需要向界面上拖动
DataGridView,并进行相关配置,选择自己需要的表即可。
插入图片的正确姿势
图片作为二进制数据无法直接拼凑出SQL命令,我们需要使用
OracleCommand自带的
Parameters功能。在SQL命令中用
:photo来代表一个参量,然后使用
sqlCom.Parameters.Add("photo", OracleDbType.Blob, imgData.Length)
来分别指定这个参量的类型和所占空间大小 最后使用
sqlCom.Parameters(0).Value = imgData
来指定这个参量的值。
整个插入图片过程的代码如下:
Dim conn As New OracleConnection(oradb) Dim imgData(0) As Byte Dim ms As New System.IO.MemoryStream PictureBox1.BackgroundImage.Save(ms, PictureBox1.BackgroundImage.RawFormat) ReDim imgData(ms.Length - 1) ms.Read(imgData, 0, ms.Length) ms.Close() conn.Open() Dim sql As String = "insert into hero values" & "(" & TextBox1.Text & ":photo" & ")" Dim sqlCom As New OracleCommand sqlCom.CommandText = sql sqlCom.Connection = conn sqlCom.Parameters.Add("photo", OracleDbType.Blob, imgData.Length) sqlCom.Parameters(0).Value = imgData sqlCom.ExecuteNonQuery()
常见错误
column not allowed here
数据类型不符,检查对应项目数据类型是否正确。
missing comma
命令格式不对,检查一下自己的SQL命令是否有错误,特别是在有字符串的时候,需要使用
""来代表一个字符串中的
"。
identifier is too long
标识符过长(不得超过30字符),不是非常明白原因,不过我取消掉insert命令中指定位置的部分之后,这个错误消失了。
missing INTO keyword
缺少into关键字(手滑打成了inte),检查一下自己的SQL命令是否有错误。
cannot insert NULL into (“SYSTEM”.“HERO”.“HEROCATEGORYID”)
这些项都指定了非0值,故不能不赋值,为对应项目赋值即可。
关键词: VS2017连接Oracle12c
个人博客
更多
前端技术文章、
美术设计、
wordpress插件、优化教程、
学习笔记尽在我的个人博客喵容 - 和你一起描绘生活,欢迎一起交流学习,一起进步:http://panmiaorong.top
站内文章推荐:
阅读更多相关文章推荐
- 如何通过AgileEAS.NET快速搭建属于你的企业应用(二)——智能版本升级和多数据库访问的分布式部署
- 如何快速测试与数据库的连接并得到连接字符串
- 如何配置Hibernate连接oracle12c 的PDB和CDB数据库
- C#如何通过配置文件连接数据库(VS2013)
- 通过beego快速创建一个Restful风格API项目及API文档自动化 本文演示如何快速(一分钟内,不写一行代码)的根据数据库及表创建一个Restful风格的API项目,及提供便于在线测试API的界
- 如何在PHP5中通过PDO连接SQLite3数据库
- 如何通过SecureCRTPortable.exe 软件远程连接某个计算机(或者虚拟机)中的某个数据库
- 如何在现有通过AttachDbFilename连接的Sql Express数据库上设置membership
- 如何在PHP5中通过PDO连接SQLite3数据库
- 如何快速测试与数据库的连接并得到连接字符串
- 数据库-如何快速创建连接字符串
- 如何快速查看oracle服务名连接的数据库的信息
- 通过建立Socket连接来快速判断数据库连接是否正确
- 如何通过使用 ADO.NET 2005 和 Visual C# 2005 或使用 ADO.NET 和 Visual C# .NET 连接到数据库并运行命令
- 如何快速创建数据库连接字符串
- java中如何通过JDBC的方式连接sqlserver2005多实例数据库?
- 通过建立Socket连接来快速判断数据库连接是否正确
- ODI如何通过logminer技术从oracle 数据库中抽取增量数据(一)
- ORACLE如何使用DBLINK连接另一个数据库[整理]
- 通过动态代理(Proxy)实现的数据库连接池的创建连接与归还链接的操作的简单的实现流程