函数给出如下:
CREATE or replace function get_data(data_key integer) return sys_refcursor
is
result1 sys_refcursor;
BEGIN
open result1 for 'Select DISTINCT COL1
FROM REF_TABLE
where DATA_KEY='||data_key;
return result1;
END;
调用上述函数
variable rc refcursor;
exec :rc :=get_data(30038);
print rc;
这在SQL开发人员中工作正常。如何使用python和sqlalchemy调用相同的内容?
我用cx_Oracle而不是SQLAlchemy,它工作了。结果输出与我对 sqlqhe 的期望相同。我将函数转换为过程。
程序
CREATE or replace procedure get_data(data_key in integer, result out
sys_refcursor) as
BEGIN
open result for 'Select DISTINCT COL1
FROM ref_table
where DATA_KEY='||data_key;
END;
使用 python 和 cx_Oracle 调用上述过程的代码
import cx_Oracle
import pandas as pd
conn = cx_Oracle.connect('system/<password>@127.0.0.1/XE')
cur = conn.cursor()
myvar = cur.var(cx_Oracle.CURSOR)
cur.callproc('get_data', (30038, myvar))
data = myvar.getvalue().fetchall()
if len(data) == 0:
data = {}
df = pd.DataFrame(data, columns=[i[0] for i in myvar.getvalue().description])
print df
上述代码的输出
COL1
--------------------------
0 219586
1 246751
2 228245
3 244517
4 220765
5 243467
6 246622
7 222784