从python脚本使用光标输出参数调用oracle存储过程 [英] Call oracle stored procedure with cursor output parameter from python script

查看:450
本文介绍了从python脚本使用光标输出参数调用oracle存储过程的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试从python脚本调用带有2 in和1 out参数的oracle存储过程。我遇到的问题是传递游标输出参数。

I am trying to call a oracle stored procedure with 2 in and 1 out parameter from python script. The problem I am having is passing a cursor out-parameter.

Oracle存储过程本质上是:

The Oracle stored procedure is essentially:

  PROCEDURE ci_lac_state 
     (LAC_ID_IN IN  VARCHAR2,  
      CI_ID_IN  IN  VARCHAR2 DEFAULT NULL,
      CGI_ID    OUT SYS_REFCURSOR)
  AS
  BEGIN
      OPEN cgi_id FOR
      ...
  END;

调用数据库的python代码为:

The python code calling to the database is:

  #! /usr/bin/python

  import cx_Oracle

  lac='11508'
  ci='9312'

  try:
      my_connection=cx_Oracle.Connection('login/passwd@db_name')
  except cx_Oracle.DatabaseError,info:
      print "Logon Error:",info
      sys.exit()

  my_cursor=my_connection.cursor()
  cur_var=my_cursor.var(cx_Oracle.CURSOR)

  my_cursor.callproc("cgi_info.ci_lac_state", [lac, ci, cur_var])

  print cur_var.getvalue()

游标值作为结果:

  <__builtin__.OracleCursor on <cx_Oracle.Connection to login@db_name>>

我在做什么错了?

谢谢。

推荐答案

我刚刚遇到过类似的问题。 cur_var 具有类型<类型'cx_Oracle.CURSOR'> cur_var.getvalue( )获取类型为<类型'OracleCursor'> 的对象。要获取数据,您必须从OracleCursor对象获取它们。尝试例如:

I've just had similar issue. cur_var has type <type 'cx_Oracle.CURSOR'> and cur_var.getvalue() gets object of type <type 'OracleCursor'>. To get data you have to fetched them from the OracleCursor object. Try for example:

print cur_var.getvalue().fetchall()

要查看OracleCursor对象的更多功能,只需检查其目录:

To see more function of OracleCursor object just check its directory:

dir(cur_var.getvalue())

希望这对您有帮助!

这篇关于从python脚本使用光标输出参数调用oracle存储过程的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆