日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

C# 连接Oracle数据库以及一些简单的操作

發布時間:2023/12/1 C# 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C# 连接Oracle数据库以及一些简单的操作 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

拖了很久今天終于在博客園寫了自己第一篇隨筆:

話不多說,我們直接進入正題:

1.連接數據庫

using (OracleConnection conn = new OracleConnection("data source=192.168.97.60/orcl;User Id=abc;Password=abc;"))
??????????? {
??????????????? conn.Open();

??????????? }

using(....){.......}:using的使用就是在與資源的釋放。

連接數據庫要知道數據庫的數據源data source,用戶名User Id,以及密碼Password,正確填寫這些,在用上面的代碼,一般連接都是成功的。

2.數據庫的增、刪、改

using (OracleConnection conn = new OracleConnection("data source=192.168.97.60/orcl;User Id=abc;Password=abc;"))
??????????? {
??????????????? conn.Open();
??????????????? using(OracleCommand cmd=conn.CreateCommand())
??????????????? {
??????????????????? cmd.CommandText = "INSERT INTO SZPT(id) VALUES (sys_guid())";
??????????????????? cmd.ExecuteNonQuery();
??????????????? }
??????????? }

必須打開數據庫連接之后才可以進行增刪改,就是說conn.Open()要放在前面,進行增刪改就用ExecuteNonQuery。

著重說明一下sys_guid(),sys_guid()會生成一個獨一無二的32的字符串,來作為唯一標示的表的主鍵。

3.獲取返回只有一行一列的數據

using (OracleConnection conn = new OracleConnection("data source=192.168.97.60/orcl;User Id=abc;Password=abc;"))
??????????? {
??????????????? conn.Open();
??????????????? using(OracleCommand cmd=conn.CreateCommand())
??????????????? {
??????????????????? cmd.CommandText = "SELECT COUNT(*) FROM SZPT";
??????????????????? decimal i= (decimal)cmd.ExecuteScalar();
??????????????????? MessageBox.Show(i.ToString());
??????????????? }
??????????? }

獲取一行一列的數據用ExecuteScalar

4.獲取返回的表

using (OracleConnection conn = new OracleConnection(connstr))
??????????? {
??????????????? conn.Open();
??????????????? using(OracleCommand cmd=new OracleCommand())
??????????????? {
??????????????????? cmd.Connection = conn;
??????????????????? cmd.CommandText = sql;
?????????????????? // cmd.Parameters.AddRange(parameters);
??????????????????? OracleDataAdapter ada = new OracleDataAdapter(cmd);
??????????????????? DataSet ds = new DataSet();
??????????????????? ada.Fill(ds);
??????????????????? return ds.Tables[0];
??????????????? }
??????????? }

5.獲取返回的ExecuteReader

?using (OracleConnection conn = new OracleConnection(connstr))
??????????? {
??????????????? conn.Open();
??????????????? using(OracleCommand cmd=new OracleCommand())
??????????????? {
??????????????????? cmd.CommandText = sql;
??????????????????? //cmd.Parameters.AddRange(parameters);
??????????????????? OracleDataReader reader= cmd.ExecuteReader();
??????????????????? while (reader.Read())
??????????????????? {
??????????????????????? reader.GetString(0);
??????????????????? }
??????????????? }
??????????? }

注意:DataSet獲得的表數據會存儲到客戶端,而ExecuteReader獲得的數據是存儲在服務端的,用ExecuteReader獲取數據的時候,如果和服務端斷開了,數據也就不會再獲得,而4當數據存儲到客戶端后,即使與服務端斷開數據依然會有。

?????? 所以當獲取的數據量不大的時候可以用DataSet把數據存儲到客戶端,如果獲取的數據量很大,最好用ExecuteReader這樣不至于客戶端的內存占用太大而至于性能不好。

?

轉載于:https://www.cnblogs.com/sxw117886/p/5363692.html

總結

以上是生活随笔為你收集整理的C# 连接Oracle数据库以及一些简单的操作的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。