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

2024-03-03

我正在尝试从 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>>

我究竟做错了什么?

Thanks.


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

print cur_var.getvalue().fetchall()

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

dir(cur_var.getvalue())

希望对你有帮助!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

从 python 脚本中使用游标输出参数调用 oracle 存储过程 的相关文章

随机推荐