MySQL使用之五_自定義函式和自定義過程
- MySQL自定義程式碼塊分為自定義函式和自定義過程兩種,函式有返回值,過程無返回值;這點和VBA中一樣;
- PostgrSQL自定義程式碼塊只有自定義函式,自定義函式可以返回void;
- 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異常,可通過捕捉該異常來判斷是否已遍歷完
異常處理
相關文章
- MySQL自定義函式與儲存過程MySql函式儲存過程
- (9)mysql 中的儲存過程和自定義函式MySql儲存過程函式
- MySQL建立自定義函式MySql函式
- mysql自定義函式篇MySql函式
- 我的MYSQL學習心得(10) : 自定義儲存過程和函式MySql儲存過程函式
- 深入mysql建立自定義函式與儲存過程的詳解MySql函式儲存過程
- MySQL全面瓦解18:自定義函式MySql函式
- 案例展示自定義C函式的實現過程函式
- shell自定義函式函式
- Oracle 自定義函式Oracle函式
- perl自定義函式函式
- mysql 自定義分析函式 least 及 日期函式MySql函式AST
- SQL優化案例-自定義函式索引(五)SQL優化函式索引
- Oracle優化案例-自定義函式索引(五)Oracle優化函式索引
- java自定義equals函式和hashCode函式Java函式
- 08.Django自定義模板,自定義標籤和自定義過濾器Django過濾器
- hive 3.0.0自定義函式Hive函式
- Hive中自定義函式Hive函式
- python 自定義函式Python函式
- oracle 自定義聚合函式Oracle函式
- Oracle中自定義函式Oracle函式
- 一個自定義函式函式
- Oracle自定義聚集函式Oracle函式
- ORACLE 自定義函式BUG?Oracle函式
- SQL SERVER 自定義函式SQLServer函式
- SQL 自定義函式FUNCTIONSQL函式Function
- SQL最佳化案例-自定義函式索引(五)SQL函式索引
- Hive常用函式及自定義函式Hive函式
- laravel 自定義全域性函式Laravel函式
- Laravel 自定義函式存放位置Laravel函式
- Laravel 新增自定義助手函式Laravel函式
- Laravel自定義輔助函式Laravel函式
- GRDB自定義的純函式函式
- HIVE中的自定義函式Hive函式
- Sql Server系列:自定義函式SQLServer函式
- Oracle自定義聚集函式薦Oracle函式
- Teradata自定義函式Replace函式
- Linux Shell 自定義函式Linux函式