我正在尝试将应用程序从 Solaris 移植到 Linux。
在 Solaris 上,我使用了 Sun Studio C++ 编译器,在 Linux 上,我使用了 Intel C++ 编译器。
现在,我在连接到 oracle 数据库时面临以下问题:
OCIDBConnection::OCIDBConnection(
Environment& _env, const STRING& dbName, const STRING& user, const STRING& password)
: env(_env)
{
COUT<<"username "<<user<<ENDL;
COUT<<"password "<<password<<ENDL;
COUT<<"dbname "<<dbName<<ENDL;
conn = env.createConnection(user, password, dbName);
}
输出如下:
username roymustang9
password roymustang9
dbname roydb
[2013-11-12 15:39:23]>>FATAL<<: Login failed.
在打印 SQLException 时,我发现:
ORA-12154: TNS:could not resolve the connect identifier specified
这很荒谬,因为名称存在于 tnanames.ora 中,并且连接细节是正确的。事实上,当我对这些值进行硬编码时,它可以正常运行:
OCIDBConnection::OCIDBConnection(
Environment& _env, const STRING& dbName, const STRING& user, const STRING& password)
: env(_env)
{
COUT<<"username "<<user<<ENDL;
COUT<<"password "<<password<<ENDL;
COUT<<"dbname "<<dbName<<ENDL;
conn = env.createConnection("roymustang9", "roymustang9", "roydb");
}
STRING 是定义为 std::string 的 typedef。COUT 和 ENDL 也是 std::cout 和 std::endl 的类型定义。
我在这里想念什么?http://docs.oracle.com/cd/B28359_01/appdev.111/b28390/reference014.htm#CHEEGFAI