在Oracle,SQLServer中游標的使用是常常的,因此在ABAP不懂是不行的......sql
一、聲明遊標數據庫
OPEN CURSOR [WITH HOLD] <c> FOR SELECT <result>ide
FROM <source>spa
[WHERE <condition>].net
[GROUP BY <fields>]code
[HAVING <cond>]blog
[ORDER BY <fields>].ci
cursor <c>需事先在data語句中聲明變量,在句型中可見,基本上select使用的全部附加項均可使用,除了一個,singleget
二、操做遊標string
向下移動遊標:FETCH NEXT CURSOR <c> INTO <target>.
關閉遊標:CLOSE CURSOR c1.
如:FETCH NEXT CURSOR S_CURSOR into TABLE itab PACKAGE SIZE S_S_IF-MAXSIZE.
FETCH NEXT CURSOR s_cursor into wa.
REPORT ydemo_rick_4. DATA: c1 TYPE cursor, "聲明遊標 c2 TYPE cursor. DATA: wa1 TYPE spfli, wa2 TYPE spfli. DATA: flag1(1) TYPE c, flag2(1) TYPE c. OPEN CURSOR: c1 FOR SELECT carrid connid FROM spfli WHERE carrid = 'LH', c2 FOR SELECT carrid connid cityfrom cityto FROM spfli WHERE carrid = 'AZ'. DO. IF flag1 NE 'X'. FETCH NEXT CURSOR c1 INTO CORRESPONDING FIELDS OF wa1. "放到一個工做區中 IF sy-subrc <> 0. "當沒數據時就關閉遊標 CLOSE CURSOR c1. flag1 = 'X'. ELSE. WRITE: / wa1-carrid, wa1-connid. ENDIF. ENDIF. IF flag2 NE 'X'. FETCH NEXT CURSOR c2 INTO CORRESPONDING FIELDS OF wa2. IF sy-subrc <> 0. CLOSE CURSOR c2. flag2 = 'X'. ELSE. WRITE: / wa2-carrid, wa2-connid, wa2-cityfrom, wa2-cityto. ENDIF. ENDIF. IF flag1 = 'X' AND flag2 = 'X'. EXIT. ENDIF. ENDDO.
下幾種狀況遊標會知動關閉
第1、執行commit work和rollback work時。
第2、當執行OpenSql數據庫提交或取消時。
第3、更改屏幕。
另,若是在open cursor時用了with hold, openSql在向數據庫提交時遊標不會自動關閉。
--------------------------------------------------------------------------------------------
動態操做數據表的遊標使用:
REPORT zles_tab_op_job. FIELD-SYMBOLS: <gs_fs>,<gt_fs> TYPE STANDARD TABLE."動態工做區,內表字段符號 DATA: gs_ref TYPE REF TO data, "動態工做區,內表引用 gt_ref TYPE REF TO data. DATA: lv_cursor TYPE cursor, lv_mes TYPE char20. DATA: lr_execption TYPE REF TO cx_root, lv_error TYPE string. PARAMETERS: p_tab TYPE tabname, p_sql TYPE string, p_num TYPE i, p_mode. CREATE DATA gt_ref TYPE TABLE OF (p_tab). ASSIGN gt_ref->* TO <gt_fs>. CREATE DATA gs_ref LIKE LINE OF <gt_fs>. ASSIGN gs_ref->* TO <gs_fs>. OPEN CURSOR WITH HOLD lv_cursor FOR SELECT * FROM (p_tab) WHERE (p_sql). DO. CLEAR <gt_fs>. TRY . FETCH NEXT CURSOR lv_cursor INTO TABLE <gt_fs> PACKAGE SIZE p_num. IF sy-subrc NE 0. CLOSE CURSOR lv_cursor. EXIT. ENDIF. CATCH cx_sy_open_sql_db INTO lr_execption. lv_error = lr_execption->get_text( ). IF lv_error IS NOT INITIAL. MESSAGE e000(oo) WITH lv_error. ENDIF. ENDTRY. CLEAR lv_mes. CASE p_mode. WHEN 'I'. INSERT (p_tab) FROM TABLE <gt_fs>. lv_mes = '插入'. WHEN 'D'. DELETE (p_tab) FROM TABLE <gt_fs>. lv_mes = '刪除'. WHEN 'M'. MODIFY (p_tab) FROM TABLE <gt_fs>. lv_mes = '修改'. WHEN 'U'. UPDATE (p_tab) FROM TABLE <gt_fs>. lv_mes = '更新'. * WHEN gs_9000-query. * PERFORM frm_alv_display."ALV查詢 ENDCASE. IF sy-subrc EQ 0. CALL FUNCTION 'DB_COMMIT'. * WRITE: '第',sy-index,'批,執行成功'. ELSE. CALL FUNCTION 'DB_ROLLBACK'. WRITE: / '第',sy-index,'批,',lv_mes,'失敗'. ENDIF. ENDDO. CLOSE CURSOR lv_cursor.
注意:當使用
CALL FUNCTION 'DB_COMMIT'. 數據提交
CALL FUNCTION 'DB_ROLLBACK'. 數據回滾
不會關閉遊標!