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這樣不至於客戶端的內存占用太大而至於性能不好。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM