彩票走势图

巧用通过Oracle游标直接操作Oracle系统表

转帖|其它|编辑:郝浩|2009-04-01 13:29:19.000|阅读 395 次

概述:在ABAP编程中,有时候需要利用Native SQL操作数据库表(自定义和非业务数据的表,业务数据表我的建议还是应该通过SAP提供的类、函数,BAPI等技术操作)。本文的例子是通过游标操作Oracle的系统表的代码,供大家参考。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

  在ABAP编程中,有时候需要利用Native SQL操作数据库表(自定义和非业务数据的表,业务数据表我的建议还是应该通过SAP提供的类、函数,BAPI等技术操作)。下面的例子是通过游标操作Oracle的系统表的代码,供大家参考。

  *---------------------------------------------------------------------*

  * Read information about partitions of a table

  *---------------------------------------------------------------------*

  FORM get_partition_info

   USING

   i_tablnm TYPE rsd_tablnm

   CHANGING

   e_ts_part_info TYPE rsdu_ts_part_info.

   DATA:

   l_s_part_info TYPE rsdu_s_part_info.

  * this works only for Oracle

   CHECK sy-dbsys = 'ORACLE'.

   EXEC SQL.

   open csr for

   select partition_name, high_value

   from user_tab_partitions

   where table_name = :i_tablnm

   ENDEXEC.

   DO.

   EXEC SQL.

   fetch next csr into :l_s_part_info-partition_name,

   :l_s_part_info-high_value

   ENDEXEC.

   IF sy-subrc <> 0.

   EXIT.

   ENDIF.

  * Special treatment of upper limit (highvalue) in Oracle

   IF l_s_part_info-high_value EQ 'MAXVALUE'.

   l_s_part_info-high_value = rsdu_c_max_value.

   ENDIF.

   INSERT l_s_part_info INTO TABLE e_ts_part_info.

   ENDDO.

   EXEC SQL.

   close csr

   ENDEXEC.

  ENDFORM. " GET_PARTITION_INFO


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn

文章转载自:CSDN

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP