最近發(fā)現(xiàn)還有不少做開發(fā)的小伙伴,在寫存儲過程的時候,在參考已有的不同的寫法時,往往很迷茫,
不知道各種寫法孰優(yōu)孰劣,該選用那種寫法,以及各種寫法優(yōu)缺點,本文以一個簡單的查詢存儲過程為例,簡單說一下各種寫法的區(qū)別,以及該用那種寫法
專業(yè)DBA以及熟悉數(shù)據(jù)庫的同學(xué)請無視。

 

廢話不多,上代碼說明,先造一個測試表待用,簡單說明一下這個表的情況

類似訂單表,訂單表有訂單ID,客戶ID,訂單創(chuàng)建時間等,查詢條件是常用的訂單ID,客戶ID,以及訂單創(chuàng)建時間

iOS培訓(xùn),Swift培訓(xùn),蘋果開發(fā)培訓(xùn),移動開發(fā)培訓(xùn)

  (,((   
      SaleOrder  (,CONCAT(,(()  )),()(),   idx_OrderNumber   idx_CustomerId   idx_OrderDate  SaleOrder(OrderDate)

iOS培訓(xùn),Swift培訓(xùn),蘋果開發(fā)培訓(xùn),移動開發(fā)培訓(xùn)

 生成的測試數(shù)據(jù)大概就是這個樣子的

 iOS培訓(xùn),Swift培訓(xùn),蘋果開發(fā)培訓(xùn),移動開發(fā)培訓(xùn)

 

 

 

下面演示說明幾種常見的寫法以及每種寫法潛在的問題

 

 

第一種常見的寫法:拼湊字符串,用EXEC的方式執(zhí)行這個拼湊出來的字符串,不推薦

iOS培訓(xùn),Swift培訓(xùn),蘋果開發(fā)培訓(xùn),移動開發(fā)培訓(xùn)

        		

網(wǎng)友評論