0

我正在尝试将应用程序从 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

4

2 回答 2

1

似乎字符串 dbName 格式不正确。也许它最后有换行符。尝试删除它:

dbName.erase(std::remove(dbName.begin(), dbName.end(), '\n'), dbName.end());
于 2013-11-13T16:50:52.703 回答
0

dbname 也可以是“roydb.world”或类似的东西

  • 首先检查您的环境变量ORACLE_HOMETNS_ADMIN
  • 然后检查输出tnsping
  • 然后检查您是否可以使用连接sqlplus
于 2013-11-13T16:51:26.347 回答