dbms_sql笔记(具体函数和示例)

43 篇文章 2 订阅
38 篇文章 0 订阅

具体函数可以参照官网
https://docs.oracle.com/cd/E11882_01/timesten.112/e21645/d_sql.htm#TTPLP71282
或者博客园这篇
DBMS_SQL使用

示例参考https://blog.51cto.com/aaron521/2165969?source=dra

调用dbms_sql需要执行五个步骤 
1.打开一个游标 
2.分析要执行的语句 
3.绑定可能需要的任何输入变量 
4.执行语句 
5.关闭游标

*/
DECLARE
  CUR   PLS_INTEGER := DBMS_SQL.OPEN_CURSOR;--为处理打开游标 ,cur 返回系统游标id
  COLS  DBMS_SQL.DESC_TAB;--DBMS_SQL.DESC_TAB:用于接收dbms_sql解析出的数据的集合类型
  NCOLS PLS_INTEGER;
BEGIN 
  --分析语句.DBMS_SQL.NATIVE:获取oracle SQL版本
  DBMS_SQL.PARSE(CUR, 'select * from ma_ctl', DBMS_SQL.NATIVE);
  --DBMS_OUTPUT.PUT_LINE(DBMS_SQL.NATIVE);  
  /*
  解析sql语句要用的数据库SQL版本,有V6,V7跟native,
  当不确定连接的ORACLE数据库版本时使用native选项。
  DBMS_SQL.NATIVE:常量名和值的关系。
  Name     Data Type     Value
  v6       INTEGER       0
  native   INTEGER       1
  v7       INTEGER       2
  */
  
  --检索出列的信息,字段数量赋值给第二个参数变量NCOLS,数据放到第三个参数COLS集合变量里
  DBMS_SQL.DESCRIBE_COLUMNS(CUR, NCOLS, COLS);
  
  FOR I IN 1 .. NCOLS LOOP
    DBMS_OUTPUT.PUT_LINE(COLS(I).COL_NAME);--COL_NAME 为COLS的一个属性,存放字段名
  END LOOP;
  DBMS_SQL.CLOSE_CURSOR(CUR);
END;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值