是否有支持无 TNS 连接(或 EZ-Connect)约定的 64 位 Oracle ODBC 驱动程序?我曾经使用“Microsoft ODBC for Oracle”,它允许无 TNS 连接字符串,但它已经贬值了很长时间并且没有 64 位版本(即它不适用于 64 位 Office/Excel ).
我的经验是,我组织中的用户有时会丢失或无效的 tnsnames.ora 文件。我想使用无 DSN 的连接字符串,因为它不 需要 tnsnames.ora,它可以在安装了正确 Oracle 驱动程序的任何计算机上成功执行。这是我旧的无 DSN、无 TNS 连接字符串的示例,它使用已弃用的“Microsoft ODBC for Oracle”驱动程序(仍然适用于 32 位办公室的用户):
DRIVER={Microsoft ODBC for Oracle}; UID=myun; PWD=mypass;
SERVER=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)
(HOST=myhostname)(PORT=1521))(CONNECT_DATA=(SID=mysid)));
我一直在尝试连接 OraClient11g_home1 中的 Oracle 来自 Oracle 的 ODBC 驱动程序,但无论我如何尝试(包括 EZ_Connect)我都无法在不需要 tnsnames.ora 的情况下工作,我不断得到这个弹出窗口,要求我指定一个服务名称:
我试过使用 EZ-Connect 和许多其他直接指定 Oracle 服务器 IP/主机名的变体,如下所示,但没有成功:
Driver={Oracle in OraClient11g_home1};Server=//OracleIPAddress:1521/MySID;
Uid=myUsername;Pwd=myPassword;
最佳答案
对于服务名称,您可以简单地插入整个 TNS 字符串,例如SERVER=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=myhostname)(PORT=1521))(CONNECT_DATA=(SID=mysid)));
用双引号括起来并删除所有回车符和空格字符。
关于excel - Oracle ODBC TNS-less 连接字符串(适用于 64 位 Excel),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26265397/