我想在我的python脚本项目的Unix中设置环境变量,该项目使用cx_Oracle与数据库连接并具有CRUD操作。
我已经使用os.environ为oracle设置环境变量。所有的库都在相应的目录中。
这是我用来设置环境变量unix的方法
def set_environment():
os.environ["TNS_ADMIN"]="/opt/oracle/orafmw/product/11.2.0.1/client_1/network/admin"
os.environ["ORACLE_HOME"] = "opt/oracle/orafmw/product/11.2.0.1/client_1"
os.environ["LD_LIBRARY_PATH"] = "/opt/oracle/orafmw/product/11.2.0.1/client_1/lib"
os.environ["PATH"] = "$PATH:/opt/oracle/orafmw/product/11.2.0.1/client_1/bin:."
并且我从脚本的main方法中调用了该方法。
def get_connect_string():
return db_username+'/'+password+'@'+host+':'+port+'/'+service_name
def main():
import os
import cx_Oracle
set_environment()
query = "SELECT * FROM SITE WHERE SITE_CODE = :1"
try:
connect_string = get_connect_string()
conn = cx_Oracle.connect(connect_string)
cur = conn.cursor()
d = cur.execute(query, ["AUS"]).fetchone()
conn.commit()
if d:
data = (([i[0] for i in cur.description]), d)
else:
data = None
except Exception as e:
print("error in operation : ", e)
conn.rollback()
finally:
conn.close()
print(data)
我收到的错误消息是:
Error while trying to retrieve text for error ORA-01804
答案 0 :(得分:0)
不能在应用程序中设置LD_LIBRARY_PATH环境变量。必须在过程开始之前进行设置!否则,它不会生效。您收到的错误表明环境设置不正确。尝试在运行脚本之前设置环境变量,看看是否可以为您解决问题!