Visual Studio 2010 在创建连接时为 Oracle OCCI 11g 提供报告"Access violation"

Visual studio 2010 reporting "Access violation" for Oracle OCCI 11g when creating connection

本文关键字:11g 报告 Access OCCI violation Oracle 2010 Studio 创建 连接 Visual      更新时间:2023-10-16

当我试图在Microsoft Visual Studio 2010上创建与Oracle OCCI 11g的连接时,我得到了以下错误:

OracleOCCI.exe中0x005a79c9处未处理的异常:0xC0000005:读取位置0x316c6561时发生访问冲突。

我的代码非常简单,如下所示:

class DMLDemo
{
private:
    Environment *env;
    Connection *conn;
    Statement *stmt;
public:
    DMLDemo (string user, string passwd, string db)
    {
        env = Environment::createEnvironment (Environment::DEFAULT);
        if(env==nullptr)
            cout << "Failure";

            try
            {
                conn = env->createConnection (user, passwd, db);
        }
            catch (exception* e)
            {
                cout << "Error";
            }

    }
    ~DMLDemo ()
    {
        env->terminateConnection (conn);
        Environment::terminateEnvironment (env);
    }
};

int _tmain(int argc, _TCHAR* argv[])
{
    //01. Test Simple Connection
    try
    {
        DMLDemo demo("scott","Michael1","");
    }
    catch (exception* e)
    {
        cout << e->what();
    }
    getche();

    return 0;
}

我在谷歌上搜索了一些答案,似乎oracle dll版本和VC版本之间的兼容性有问题。

有人能解决这个问题吗?还是改为VS 2005?

我一直在构建与Oracle 11g(11.2.0)32位数据库的VS08和VS10接口。我发现许多提供occi11x.dll的网站,包括我自己在V9目录中安装的Oracle,与VS08控制台应用程序不兼容。最后,我不得不让经过测试的"黄金"二进制文件从公司的另一个地方交付给我。一旦x86"gold"dll安装在控制台启动目录中,相同的代码就可以正常工作。

我正在VS10 occi11x.dll中搜索相同的适用性。到目前为止,我还没有找到它。在创建环境后,我遇到了类似的错误。有些dll允许我建立连接,但当我尝试执行ResultSet->next()时出错,其他dll甚至不允许我执行executeQuery()。我认为甲骨文没有妥善管理这件事是失职。

"已损坏"的VS08 dll有时与"黄金"dll具有正确的日期和文件大小。也许对dll进行内部搜索会发现哪些是可行的。

http://www.oracle.com/technetwork/database/occidownloads-083553.html是oracle用来提供各种occi dll以匹配Visual Studio的网站。也许他们的VS12版本实际上与Oracle12c数据库更兼容。

好的,我终于安装了VS2008,代码运行良好。2008年编译的Oracle DLL似乎在VS2010中不起作用。

也许有一天,Oracle可以发布其VS2010 DLL。。。