濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > VS2015連接Oracle數(shù)據(jù)庫(kù)的詳細(xì)步驟

VS2015連接Oracle數(shù)據(jù)庫(kù)的詳細(xì)步驟

熱門(mén)標(biāo)簽:圖像地圖標(biāo)注 南寧人工智能電銷機(jī)器人費(fèi)用 分布式呼叫中心 濟(jì)南地圖標(biāo)注公司 海南400電話哪里辦理 安陽(yáng)外呼系統(tǒng)免費(fèi) 呼倫貝爾智能手機(jī)地圖標(biāo)注 400電話是不是免費(fèi)申請(qǐng) 貴陽(yáng)電話外呼系統(tǒng)哪家好

開(kāi)發(fā)環(huán)境

宿主機(jī):Win10 + VS2015 + ODP.Net for VS2015 虛擬機(jī):Win7 + Oracle 11g + 橋接

配置ODP.Net

首先下載 Oracle Developer Tools for Visual Studio 2015 ,下載此文件需要注冊(cè)O(shè)racle社區(qū)賬號(hào)并接受相關(guān)的協(xié)議,此文件提供了以下組件:

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

下載完成后運(yùn)行MSI安裝程序進(jìn)行安裝,安裝完成后會(huì)自動(dòng)注冊(cè)VS2015的相關(guān)插件,重新啟動(dòng)VS2015后將會(huì)看到Oracle的相關(guān)命令,比如SQL *PLUS支持等。同時(shí)添加數(shù)據(jù)庫(kù)時(shí)也能看到相應(yīng)的選項(xiàng)。

ODP.Net支持所有Oracle版本,因此下載時(shí)只需要注意VS的版本即可。

配置tnsnames.ora

ODP.Net默認(rèn)使用安裝目錄下的tnsnames.ora,若安裝目錄在Program Files下,可能會(huì)遇到無(wú)權(quán)限等問(wèn)題,此時(shí)使用管理員權(quán)限打開(kāi)命令行,切換到對(duì)應(yīng)目錄并使用notepad編輯。

復(fù)制服務(wù)器端的tnsnames.ora文件內(nèi)容,或者自己手動(dòng)編輯,格式如下:

數(shù)據(jù)源別名> =
 (DESCRIPTION =
  (ADDRESS = (PROTOCOL = TCP)(HOST = 主機(jī)名或IP>)(PORT = 端口號(hào)>))
  (CONNECT_DATA =
   (SERVER = DEDICATED)
   (SERVICE_NAME = 數(shù)據(jù)庫(kù)服務(wù)名>)
  )
 )

添加數(shù)據(jù)庫(kù)

打開(kāi)工具-連接到數(shù)據(jù)庫(kù),數(shù)據(jù)源修改為Oracle數(shù)據(jù)庫(kù)下的ODP.NET,托管驅(qū)動(dòng)程序,然后點(diǎn)擊確定,打開(kāi)添加連接窗口。

填寫(xiě)用戶名,密碼并選擇數(shù)據(jù)源,然后測(cè)試連接,成功的話說(shuō)明已經(jīng)連通,點(diǎn)擊確定即可。

使用虛擬機(jī)搭建數(shù)據(jù)庫(kù)的額外Tips 根據(jù)某網(wǎng)友分析,Oracle的監(jiān)聽(tīng)器在通過(guò)1521端口連接后,會(huì)開(kāi)啟另外一個(gè)新的隨機(jī)端口進(jìn)行數(shù)據(jù)通訊,因此使用NAT方式虛擬網(wǎng)卡可能會(huì)導(dǎo)致連接失敗。這種情況下,請(qǐng)使用橋接方式虛擬網(wǎng)卡,并在net manager中將loaclhost修改為虛擬機(jī)當(dāng)前的IP。重啟監(jiān)聽(tīng)服務(wù)后,再試。

連接數(shù)據(jù)庫(kù)并使用

連接數(shù)據(jù)庫(kù)

Dim oradb As String = "User ID=system;Password=123456;Data Source=lol"
Dim conn As New OracleConnection(oradb)
conn.Open()
Dim sql As String = "create table xxx"
Dim sqlCom As New OracleCommand
sqlCom.CommandText = sql
sqlCom.Connection = conn
sqlCom.ExecuteNonQuery()

查詢數(shù)據(jù)

成功配置數(shù)據(jù)源之后,只需要向界面上拖動(dòng)DataGridView,并進(jìn)行相關(guān)配置,選擇自己需要的表即可。

插入圖片的正確姿勢(shì)

圖片作為二進(jìn)制數(shù)據(jù)無(wú)法直接拼湊出SQL命令,我們需要使用OracleCommand自帶的Parameters功能。在SQL命令中用:photo來(lái)代表一個(gè)參量,然后使用

sqlCom.Parameters.Add("photo", OracleDbType.Blob, imgData.Length)

來(lái)分別指定這個(gè)參量的類型和所占空間大小

最后使用

sqlCom.Parameters(0).Value = imgData

來(lái)指定這個(gè)參量的值。

整個(gè)插入圖片過(guò)程的代碼如下:

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()

常見(jiàn)錯(cuò)誤

column not allowed here

數(shù)據(jù)類型不符,檢查對(duì)應(yīng)項(xiàng)目數(shù)據(jù)類型是否正確。

missing comma
命令格式不對(duì),檢查一下自己的SQL命令是否有錯(cuò)誤,特別是在有字符串的時(shí)候,需要使用""來(lái)代表一個(gè)字符串中的"。

identifier is too long
標(biāo)識(shí)符過(guò)長(zhǎng)(不得超過(guò)30字符),不是非常明白原因,不過(guò)我取消掉insert命令中指定位置的部分之后,這個(gè)錯(cuò)誤消失了。

missing INTO keyword
缺少into關(guān)鍵字(手滑打成了inte),檢查一下自己的SQL命令是否有錯(cuò)誤。

cannot insert NULL into (“SYSTEM”.”HERO”.”HEROCATEGORYID”)
這些項(xiàng)都指定了非0值,故不能不賦值,為對(duì)應(yīng)項(xiàng)目賦值即可。

下面是其它網(wǎng)友的補(bǔ)充:

1.下載Oracle Developer Tools for Visual Studio 2015 ,網(wǎng)址如下。

 安裝好后參照oracle的安裝目錄下的 tnsnames.ora文件的最后一段修改Oracle Developer Tools for Visual Studio 2015安裝目錄下的 tnsnames.ora文件的最后一 段(直接復(fù)制)我的如下ORCL =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
) F:\app\sky\product\11.2.0\dbhome_1\NETWORK\ADMIN

3.打開(kāi)vs會(huì)發(fā)現(xiàn)工具選項(xiàng)里面多了sqlplus等roacle的內(nèi)容,在項(xiàng)目的引用上點(diǎn)擊右鍵添加引用-擴(kuò)展-選擇Oracle.ManageDataAccess
ManageDataAccess筆以前的DataAccess更好用,不用考慮64位32位的問(wèn)題
4.通過(guò)如下代碼測(cè)試是否連接成功

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Oracle.ManagedDataAccess.Client;//dll引用


namespace test
{
  class Program
  {
    static void Main(string[] args)
    {
      string connString = "Data Source=orcl;User Id=zzw;Password=123456";
      OracleConnection conn = new OracleConnection();
      conn.ConnectionString = connString;
      conn.Open();
      Console.WriteLine("Connection State:" + conn.State);
      conn.Close();
      Console.ReadLine();
    }
  }
}

 如果控制臺(tái)輸出信息為open表示連接成功

您可能感興趣的文章:
  • 使用JDBC連接ORACLE的三種URL格式
  • Spring Boot整合MyBatis連接Oracle數(shù)據(jù)庫(kù)的步驟全紀(jì)錄
  • Python3.6連接Oracle數(shù)據(jù)庫(kù)的方法詳解
  • Oracle 配置連接遠(yuǎn)程數(shù)據(jù)庫(kù)的教程
  • WINDOWS下使用DOS命令行連接oracle數(shù)據(jù)庫(kù)
  • python cx_Oracle的基礎(chǔ)使用方法(連接和增刪改查)
  • C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll
  • Oracle出現(xiàn)ora-12154無(wú)法解析指定連接標(biāo)識(shí)符的解決方法
  • PowerDesigner15.1連接oracle11g逆向生成ER圖
  • Oracle數(shù)據(jù)庫(kù)url連接最后一個(gè)orcl代表的是配置的數(shù)據(jù)庫(kù)SID

標(biāo)簽:郴州 涼山 焦作 滁州 許昌 遼源 南充 合肥

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《VS2015連接Oracle數(shù)據(jù)庫(kù)的詳細(xì)步驟》,本文關(guān)鍵詞  VS2015,連接,Oracle,數(shù)據(jù)庫(kù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《VS2015連接Oracle數(shù)據(jù)庫(kù)的詳細(xì)步驟》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于VS2015連接Oracle數(shù)據(jù)庫(kù)的詳細(xì)步驟的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    台江县| 霍城县| 三穗县| 阿拉善左旗| 玛纳斯县| 修水县| 克什克腾旗| 芜湖市| 江达县| 聊城市| 翼城县| 咸丰县| 峨边| 明溪县| 神池县| 南江县| 南投市| 易门县| 大安市| 宜黄县| 高唐县| 富源县| 松桃| 芒康县| 岳池县| 青铜峡市| 屏边| 理塘县| 马山县| 武鸣县| 石家庄市| 涞水县| 岗巴县| 连城县| 玉田县| 雅江县| 阿尔山市| 南丹县| 麦盖提县| 大埔区| 交城县|