ORACLE连接遇到的错误记录
错误描述
错误原因
-
原因1:负载均衡时:
由于oracle 是做的多节点,然后有一个公用的service_name,只有通过service_name去连接才能起到负载均衡的作用,而以cx_Oracle默认的连接串去连的话只能连接到实例名,而不能连接到service_name,所以oracle用service_name去匹配实例名,当然找不到。所以连接时必须指定连的是service_name而不是sid。 -
原因2:你的user和name写反了,也就是你的用户名密码实例名输入不正确,若搞不清楚建议看下Navicat中oracle的连接信息。
负载均衡时SID报错解决方案
修改SQLAlchemy连接字符串的连接方式
import cx_Oracle
from sqlalchemy import create_engine
ip = 'xx.xx.xx.xx'
port = 'xxxx'
uname = 'xxxxxx' # 用户名
pwd = 'xxxxxx' # 密码
tnsname = 'xxxxxx' # 实例名
try:
#创建连接对象
dsnStr = cx_Oracle.makedsn(ip, port, service_name=tnsname)
connect_str = "oracle://%s:%s@%s" %(uname, pwd, dsnStr)
engine = create_engine(connect_str, encoding=encoding)
#cx_Oracle连接
conn = cx_Oracle.connect(uname, pwd, dsn=dsnStr)
except:
print('连接失败')
个人体会
- 在公司测试环境下oracle数据库是实体的,单个的,独立的,不指定service_name也能正常连接。
- 在客户生产环境下oracle是虚拟的,集群的,就一定要指定service_name才能连接。
- 若程序找不到dll就报oracle的oracle.dll文件放到项目目录下。