[置顶] oracle数据库连接问题

   今天使用360保险箱把oracle的很多文件给删掉了,造成oracle无法使用。狠心重装了oracle。连接内网的数据库服务器测试连接成功。兴致勃勃啊。
   但是在使用PL/SQL Developer时,连接不上。报
      Initialization error
     Could not locate OCI dll
     OracleHomeKey:SOFTWARE\ORACLE\KEY_OraClient10g_home3
     OracleHomeDir:D:\Oracle\product\10.1.0\Client_1
   很多人说的解决办法:
   1、缺少oci.dll。我的没有缺少该文件;
   2、打开PL/SQL Developer--》Tools--》Preferences即图一画面,然后在图2画面中把Oracle home以及oci.dll的路径配置一下即可。我的进去之后Oracle home可以选择,但是oci.dll没有可选择的项。
   开始进行自己手动修复,修改E:\oracle\product\10.2.0\db_1\NETWORK\ADMIN下的tnsnames.ora文件
IP50 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 172.17.5.50)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SID = ORCL)
    )
  )修改之后没效果。又还原回去。
  查看环境变量 ,修改与安装的oracle路径不一样的地方,没有问题。
  这几步操作之后问题依然没有解决,在网上有人说可能原因在于注册表中,我进入注册表发现我上一个oracle的注册表没有删除干净。删掉那个不用的oracle_home。
   重启PL/SQL Developer,连接,success!

后续:上面的操作事实上是错误的。在我第二天就突然发现我的oracle启动不了了。追究原因就是上面删掉了注册表的内容。
    在思索注册表恢复没有成功的情况下,就又重新安装了Oracle。
    问题根源在于:
        在我的电脑上面即安装了Oracle Server 也有Client。在Pl/sql developer中由于是先于Oracle安装的,里面的Oracle-home不知道是哪一个。所以,我在连接外部的数据库的时候就设置Oracle-home为客户端的。这样就解决了问题。希望之前的错误操作没有给大家造成太大影响。
    以上只是个人观点,注意甄别。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用C编写的程序,可以将窗口置顶显示,并从SQLite数据库中读写数据并将其显示在窗口中: 首先,需要使用SQLite API连接数据库。在这个例子中,我们假设数据库文件名为example.db,它包含一个名为example_table的表,其中包含一个整数id和一个字符串name。连接数据库的代码如下: ```c #include <sqlite3.h> sqlite3 *db; sqlite3_open("example.db", &db); ``` 接下来,可以使用SQLite API执行查询并从数据库中检索数据。以下代码从example_table中选择所有行,并使用sqlite3_column_*函数从结果集中检索数据: ```c sqlite3_stmt *stmt; sqlite3_prepare_v2(db, "SELECT id, name FROM example_table", -1, &stmt, NULL); while (sqlite3_step(stmt) == SQLITE_ROW) { int id = sqlite3_column_int(stmt, 0); const unsigned char *name = sqlite3_column_text(stmt, 1); // 在窗口中显示数据 } ``` 最后,可以使用操作系统提供的API来创建窗口并将数据显示在其中。以下是一个使用WinAPI创建窗口的示例代码: ```c #include <windows.h> LRESULT CALLBACK WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam); int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) { // 创建窗口 HWND hWnd = CreateWindowEx(WS_EX_TOPMOST, "MyWindowClass", "My Window", WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, 640, 480, NULL, NULL, hInstance, NULL); // 显示窗口 ShowWindow(hWnd, nCmdShow); UpdateWindow(hWnd); // 进入消息循环 MSG msg; while (GetMessage(&msg, NULL, 0, 0)) { TranslateMessage(&msg); DispatchMessage(&msg); } // 关闭数据库连接 sqlite3_close(db); return msg.wParam; } LRESULT CALLBACK WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) { switch (msg) { // 处理绘制窗口的消息 case WM_PAINT: // 在窗口中绘制数据 break; // 处理关闭窗口的消息 case WM_DESTROY: PostQuitMessage(0); break; default: return DefWindowProc(hWnd, msg, wParam, lParam); } return 0; } ``` 在WndProc函数中处理窗口消息,例如在WM_PAINT消息中绘制数据,并在WM_DESTROY消息中关闭窗口。 请注意,以上代码只是示例代码,需要根据具体情况进行修改和完善。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值