使用python脚本中的游标输出参数调用oracle存储过程

时间:2013-09-30 13:36:35

标签: python oracle stored-procedures cursor cx-oracle

我试图用python脚本中的2进1出参数调用oracle存储过程。我遇到的问题是将光标传递给参数。

Oracle存储过程基本上是:

  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代码是:

  #! /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>>

我做错了什么?

感谢。

2 个答案:

答案 0 :(得分:1)

我刚才有类似的问题。 cur_var的类型为<type 'cx_Oracle.CURSOR'>cur_var.getvalue()的对象类型为<type 'OracleCursor'>。要获取数据,必须从OracleCursor对象中获取数据。试试例如:

print cur_var.getvalue().fetchall()

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

dir(cur_var.getvalue())

希望这会对你有帮助!

答案 1 :(得分:0)

您可以定义输出,然后使用如下隐式游标进行遍历:

outVal = cursor.var(cx_Oracle.CURSOR)

something = cursor.callproc(<your procedure name>, [outVal,<input variable here>])

for implicitCursor in cursor.getimplicitresults():
    for row in implicitCursor:
        
        fout.write(''.join(row)) # note: tuple conversion inside ()
        fout.write('\n')