MySQL使用之五_自定義函式和自定義過程

IMchg發表於2020-12-22
  1. MySQL自定義程式碼塊分為自定義函式和自定義過程兩種,函式有返回值,過程無返回值;這點和VBA中一樣;
  2. PostgrSQL自定義程式碼塊只有自定義函式,自定義函式可以返回void;
  3. MySQL和PostgreSQL的自定義函式寫法不同

遊標

SQL語句執行時,是欄位對所有行進行操作的,也就是自帶迴圈,得到的結果為記錄的集合而不是一條記錄,那怎麼遍歷取出結果集中的每條記錄?通過遊標的機制,遊標就和中迭代器差不多
在不使用遊標時操作針對整個集合
使用遊標操作針對單個記錄


語句結束符


變數定義

@,@@、#,##的含義
參考:https://zhidao.baidu.com/question/238197938.html

變數


條件語句:


迴圈語句:

迴圈結束

LEAVE 相當於 break
ITERATE 相當於 continue

LOOP迴圈

LOOP
SET @count=@count+1;  
END LOOP;
LOOP語句本身不帶條件判斷和迴圈結束,需要自己寫IF和LEAVE來結束迴圈
add_num: LOOP 
SET @count=@count+1; 
IF @count=100 THEN 
LEAVE add_num ; 
END LOOP add_num ; 

REPEAT迴圈

REPEAT 
SET @count=@count+1; 
UNTIL @count=100 
END REPEAT ; 

WHILE迴圈

WHILE @count<100 DO 
SET @count=@count+1; 
END WHILE ; 

Cursor

注意:Cursor相當於迭代器,需判斷是否遍歷到資料集末尾;SQL中,若Cursor已到末尾,但仍然用Fetch取值,會產生NOT FOUND異常,可通過捕捉該異常來判斷是否已遍歷完


異常處理

相關文章