亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

VS2015連接Oracle數據庫的詳細步驟

2020-07-26 14:03:27
字體:
來源:轉載
供稿:網友

開發環境

宿主機: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 OracleCommandsqlCom.CommandText = sqlsqlCom.Connection = connsqlCom.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 ByteDim ms As New System.IO.MemoryStreamPictureBox1.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 OracleCommandsqlCom.CommandText = sqlsqlCom.Connection = connsqlCom.Parameters.Add("photo", OracleDbType.Blob, imgData.Length)sqlCom.Parameters(0).Value = imgDatasqlCom.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表示連接成功

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线观看不卡av| 亚洲第一av在线| 狠狠躁天天躁日日躁欧美| 国产精国产精品| 亚洲v日韩v综合v精品v| 97av在线播放| 国产91精品最新在线播放| 国内精品模特av私拍在线观看| 国产精品日韩电影| 久久久久久亚洲精品| 1769国内精品视频在线播放| 成人国产精品日本在线| 国产精品久久久久久久久久尿| 性欧美视频videos6一9| 成人一区二区电影| 欧美黑人极品猛少妇色xxxxx| 亚洲天堂日韩电影| 夜夜嗨av色综合久久久综合网| 国产精品日韩欧美大师| 日本一本a高清免费不卡| 国产免费亚洲高清| 日韩视频免费看| 另类色图亚洲色图| 国产日韩欧美在线观看| 91精品免费久久久久久久久| 18久久久久久| 日韩成人在线视频网站| 91经典在线视频| 美女黄色丝袜一区| 亚洲精品wwww| 欧美高清在线播放| 亚洲人成免费电影| 国产精品久久久久久av下载红粉| 色综合亚洲精品激情狠狠| 欧美成在线观看| 欧美高清videos高潮hd| 色yeye香蕉凹凸一区二区av| 国产精品海角社区在线观看| 亚洲香蕉伊综合在人在线视看| 777午夜精品福利在线观看| 久久深夜福利免费观看| 中文字幕欧美在线| 日本成人激情视频| 欧美极品少妇xxxxⅹ裸体艺术| 欧美性受xxxx黑人猛交| 国产精品永久免费视频| 欧美黄色片在线观看| 亚洲小视频在线| 欧美性生交大片免网| 久久色精品视频| 欧美精品videos| 欧美丰满片xxx777| 亚洲一区二区少妇| 国产精品欧美激情在线播放| 97视频在线观看成人| 色噜噜国产精品视频一区二区| 欧美性猛交99久久久久99按摩| 国产日韩在线亚洲字幕中文| 国产精品久久久久久影视| 亚洲欧美色图片| 92裸体在线视频网站| 亚洲精品自拍视频| 久久久久免费精品国产| 久久五月情影视| 亚洲片在线资源| 国模极品一区二区三区| 精品国产欧美一区二区五十路| 91亚洲va在线va天堂va国| 国产综合视频在线观看| 成人在线视频网站| 亚洲午夜性刺激影院| 欧美专区第一页| 国产精品偷伦一区二区| 日韩国产欧美精品在线| 91精品国产成人www| 国产综合视频在线观看| 欧美伊久线香蕉线新在线| 992tv成人免费视频| 国产va免费精品高清在线| 欧美日韩国产精品一区二区三区四区| 国语自产精品视频在线看| 国产精品对白刺激| 久久视频在线视频| 亚洲精品98久久久久久中文字幕| 日韩日本欧美亚洲| 欧美精品手机在线| 2019中文字幕全在线观看| 欧美疯狂做受xxxx高潮| 亚洲一区二区在线播放| 91丨九色丨国产在线| 欧美视频一二三| 日韩一区二区av| 国产精品久久视频| 久久久精品2019中文字幕神马| 成人福利网站在线观看| 亚洲国产日韩精品在线| 国产91色在线播放| 国产精品狼人色视频一区| 成人免费观看网址| 亚洲精品美女久久| 欧美日韩中文字幕综合视频| 不卡av在线网站| 亚洲福利在线视频| 国产精品爱啪在线线免费观看| 中文.日本.精品| 国产欧美日韩精品丝袜高跟鞋| 欧美成人精品三级在线观看| 97视频在线播放| 久久精品国产一区| 亚洲电影免费观看高清完整版| 国产日韩欧美一二三区| 亚洲成人黄色在线| 一区二区福利视频| 亚洲free性xxxx护士白浆| 亚洲最大的成人网| 亚洲第一黄色网| 日韩免费精品视频| 久久久亚洲欧洲日产国码aⅴ| 欧洲亚洲在线视频| 亚洲国产日韩精品在线| 国产精品成人久久久久| 国产欧美婷婷中文| 国产人妖伪娘一区91| 一个人www欧美| 97视频人免费观看| 91精品国产91久久久久久| 久久久久久999| 日韩精品在线观看一区二区| 热re99久久精品国产66热| 欧美日韩国产91| 欧美国产中文字幕| 亚洲精品91美女久久久久久久| 91免费视频网站| 国产在线拍揄自揄视频不卡99| 欧美野外wwwxxx| 狠狠躁夜夜躁人人躁婷婷91| 91国内产香蕉| 日韩av电影在线免费播放| 日韩欧美亚洲范冰冰与中字| 色av吧综合网| 国产精品高潮呻吟久久av黑人| 91在线视频精品| 亚洲精品久久久久久久久久久| 成人亚洲综合色就1024| 国产日产亚洲精品| 亚洲色图av在线| 午夜精品福利在线观看| 性色av一区二区三区红粉影视| 欧美日韩精品中文字幕| 亚洲激情视频网站| 精品国产一区二区三区久久久| 97久久精品在线| 国产精品久久久久久av下载红粉| 日韩黄色高清视频| 国产成人欧美在线观看| 亚洲国产精品va在线看黑人动漫| 国产福利精品视频| 久久综合网hezyo| 一区二区三区 在线观看视| 国产精品第一第二| 精品日韩中文字幕| 久久久久久久91| 成人国产精品一区二区| 国内揄拍国内精品|