先說一下儲存過程 解釋搬運
sql語句需要先編譯然後執行,而儲存過程(stored procedure)是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數(如果該儲存過程帶有引數)來呼叫執行它。
儲存過程是可程式設計的函式,在資料庫中建立並儲存,可以由sql語句和控制結構組成。當想要在不同的應用程式或平台上執行相同的函式,或者封裝特定功能時,儲存過程是非常有用的。資料庫中的儲存過程可以看做是對程式設計中物件導向方法的模擬,它允許控制資料的訪問方式。
儲存過程的優點:
(1).增強sql語言的功能和靈活性:儲存過程可以用控制語句編寫,有很強的靈活性,可以完成複雜的判斷和較複雜的運算。
(2).標準元件式程式設計:儲存過程被建立後,可以在程式中被多次呼叫,而不必重新編寫該儲存過程的sql語句。而且資料庫專業人員可以隨時對儲存過程進行修改,對應用程式源**毫無影響。
(3).較快的執行速度:如果某一操作包含大量的transaction-sql**或分別被多次執行,那麼儲存過程要比批處理的執行速度快很多。因為儲存過程是預編譯的。在首次執行乙個儲存過程時查詢,優化器對其進行分析優化,並且給出最終被儲存在系統表中的執行計畫。而批處理的transaction-sql語句在每次執行時都要進行編譯和優化,速度相對要慢一些。
(4).減少網路流量:針對同乙個資料庫物件的操作(如查詢、修改),如果這一操作所涉及的transaction-sql語句被組織進儲存過程,那麼當在客戶計算機上呼叫該儲存過程時,網路中傳送的只是該呼叫語句,從而大大減少網路流量並降低了網路負載。
(5).作為一種安全機制來充分利用:通過對執行某一儲存過程的許可權進行限制,能夠實現對相應的資料的訪問許可權的限制,避免了非授權使用者對資料的訪問,保證了資料的安全。
show procedure status; #展示已有的儲存過程還有詳細資訊
mysql會把儲存過程當做sql語句執行,所以會把;處理,這樣在sql語句那裡就停住了,導致儲存過程失敗,所以要宣告乙個新的分隔符,然後別忘了在儲存過程結束後把分隔符還原。
儲存過程的方法不管傳不傳參都要有括號
使用儲存過程
寫帶引數的儲存過程時候 我建的表字符集不對導致了中文查不出來 需要注意一下
drop procedure `select_username`;
thinkphp5中使用儲存過程 db()->query('call select_username("張2")') ; 返回二維陣列
mysql 儲存過程簡單使用
使用場景 因為資料庫單錶增量較大,考慮將該錶水平拆分,分成32張表,路由欄位為使用者id,按照使用者id 32將資料散落到各個分表中,中介軟體採用sharding sphere。表拆分完成以後,遇到尷尬的問題,生成相同結構的表,所以此處採用了儲存過程輔助生成表。根據現有表結構建立表 create t...
mysql 儲存過程簡單使用
需要將乙個複雜的邏輯單元進行封裝,遮蔽使用者對細節關注 案例 因為資料庫單錶增量較大,考慮將該錶水平拆分,分成32張表,路由欄位為使用者id,按照使用者id 32將資料散落到各個分表中,中介軟體採用sharding sphere。表拆分完成以後,遇到尷尬的問題,生成相同結構的表,所以此處採用了儲存過...
Mysql儲存過程使用
案例 create procedure sp insert graduate certificate in psid varchar 200 in certificateid int 32 in number varchar 50 in userid int 32 in starttime date...