Oracle——基礎知識

來源:互聯網
上載者:User

標籤:style   使用   ar   strong   資料   sp   問題   on   ef   

一、 oracle 與 SqlServer 的區別:

類別 oracle SqlServer
連接字串 || +
變數 變數名 @變數名
初始賦值 := =
SQL語句賦值 into =
綁定變數 =:變數名 [email protected]變數名
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     

 

 

1、聲明變數:

  declare 變數名 變數類型;  //與SqlServer不同,變數無需@

  例   declare   a varchar2(20);

 

 

=:應該相當於   a  =   :b   表明b是個綁定變數,需要執行時進行變數綁定
:= 相當於一般程式設計語言中的 賦值 a := 1 即將 數字1賦值給變數 a
=:   後面是要接變數 
:= 是在procdure中接常量值
變數綁定 是指在sql語句的條件中使用變數而不是常量。比如shared pool裡有兩條sql語句,
select * from tab1 where col1=1;
select * from tab1 where col1=2;
對oracle資料庫來說,這是兩條完全不同的SQL,對這兩條語句都需要進行hard parse。因為oracle會根據sql語句的文本去計算每個字元在記憶體裡的hash值,因此雖然上述兩條SQL只有一個字元不一樣,oracle根據hash演算法在記憶體中得到的hash地址就不一樣,所以oracle就會認為這是兩條完全不同的語句。而如果將上述SQL改寫成select * from tab1 where col1=:var1;,然後通過對變數var1的賦值去查詢,那麼oracle對這條語句第一次會進行hard parse,以後就只進行soft parse。假設某條語句被重複執行了幾十萬次,那麼使用bind var帶來的好處是巨大的。一個應用程式如果bind var使用不充分,那麼幾乎一定會伴隨著嚴重的效能問題。

綁定變數是相對文本變數來講的,所謂文本變數是指在SQL直接書寫查詢條件,這樣的SQL在不同條件下需要反覆解析,綁定變數是指使用變數來代替直接書寫條件,查詢bind value在運行時傳遞,然後綁定執行。優點是減少硬解析,降低CPU的爭用,節省shared_pool ;缺點是不能使用histogram,sql最佳化比較困難

Oracle——基礎知識

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.