VS2015連線Oracle資料庫的詳細步驟
開發環境
宿主機:Win10 + VS2015 + ODP.Net for VS2015 虛擬機器:Win7 + Oracle 11g + 橋接
配置ODP.Net
首先下載 Oracle Developer Tools for Visual Studio 2015 ,下載此檔案需要註冊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 = <資料庫服務名>) ) )
新增資料庫
開啟工具-連線到資料庫,資料來源修改為Oracle資料庫下的ODP.NET,託管驅動程式,然後點選確定,開啟新增連線視窗。
填寫使用者名稱,密碼並選擇資料來源,然後測試連線,成功的話說明已經連通,點選確定即可。
使用虛擬機器搭建資料庫的額外Tips 根據某網友分析,Oracle的監聽器在通過1521埠連線後,會開啟另外一個新的隨機埠進行資料通訊,因此使用NAT方式虛擬網絡卡可能會導致連線失敗。這種情況下,請使用橋接方式虛擬網絡卡,並在net manager中將loaclhost修改為虛擬機器當前的IP。重啟監聽服務後,再試。
連線資料庫並使用
連線資料庫
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()
查詢資料
成功配置資料來源之後,只需要向介面上拖動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,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",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值,故不能不賦值,為對應專案賦值即可。
下面是其它網友的補充:
1.下載Oracle Developer Tools for Visual Studio 2015 ,網址如下。
安裝好後參照oracle的安裝目錄下的 tnsnames.ora檔案的最後一段修改Oracle Developer Tools for Visual Studio 2015安裝目錄下的 tnsnames.ora檔案的最後一 段(直接複製)我的如下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.開啟vs會發現工具選項裡面多了sqlplus等roacle的內容,在專案的引用上點選右鍵新增引用-擴充套件-選擇Oracle.ManageDataAccess
ManageDataAccess筆以前的DataAccess更好用,不用考慮64位32位的問題
4.通過如下程式碼測試是否連線成功
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(); } } }
如果控制檯輸出資訊為open表示連線成功