原文地址:https://xuanwo.org/2016/01/03/vs-oracle-11g
開發環境
宿主機: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文件內容,或者自己手動編輯,格式如下:
1 |
<數據源別名> = |
添加數據庫
打開工具
-連接到數據庫
,數據源修改為Oracle數據庫
下的ODP.NET,托管驅動程序
,然后點擊確定
,打開添加連接
窗口。
填寫用戶名,密碼並選擇數據源,然后測試連接,成功的話說明已經連通,點擊確定即可。
使用虛擬機搭建數據庫的額外Tips
根據某網友分析,Oracle的監聽器在通過1521端口連接后,會開啟另外一個新的隨機端口進行數據通訊,因此使用NAT方式虛擬網卡可能會導致連接失敗。這種情況下,請使用橋接方式虛擬網卡,並在net manager
中將loaclhost
修改為虛擬機當前的IP。重啟監聽服務后,再試。
連接數據庫並使用
連接數據庫
1 |
Dim oradb As String = "User ID=system;Password=123456;Data Source=lol" |
查詢數據
成功配置數據源之后,只需要向界面上拖動DataGridView
,並進行相關配置,選擇自己需要的表即可。
插入圖片的正確姿勢
圖片作為二進制數據無法直接拼湊出SQL命令,我們需要使用OracleCommand
自帶的Parameters
功能。在SQL命令中用:photo
來代表一個參量,然后使用
1 |
sqlCom.Parameters.Add("photo", OracleDbType.Blob, imgData.Length) |
來分別指定這個參量的類型和所占空間大小
最后使用
1 |
sqlCom.Parameters(0).Value = imgData |
來指定這個參量的值。
整個插入圖片過程的代碼如下:
1 |
Dim conn As New OracleConnection(oradb) |
常見錯誤
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值,故不能不賦值,為對應項目賦值即可。