我试图用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>>
我做错了什么?
感谢。
答案 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')