【发布时间】:2014-10-31 22:50:37
【问题描述】:
我是Oracle新手,今天安装了Oracle 11g Express Edition。 然后我安装了 Java SDK,然后是免费的 Oracle SQL Developer。 我连接了系统帐户并创建了如下定义的用户名和表。我不完全了解 Oracle 的工作原理,我认为使用用户名而不是数据库名称。所以下面是详细信息。
用户名/连接/数据库 = CustomSearch
表=Reservation_General_2
该表中有一些列和一些数据。但关键是我无法连接到 Oracle 服务器。
这是我尝试连接到数据库服务器的方式。
<?php
/**
* Created by PhpStorm.
* User: HaiderHassan
* Date: 9/3/14
* Time: 9:52 PM
*/
header('Access-Control-Allow-Origin: *');
$tns = "
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = orcl)
)
)
";
try {
$conn = new PDO("oci:dbname=".$tns, 'customsearch', 'babaji');
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch(PDOException $e) {
echo 'ERROR: ' . $e->getMessage();
}
问题是当我尝试打开该页面时,出现此错误。
错误:找不到驱动程序
这些是我从Oracle Sql Developer 连接时的连接设置。
我做错了什么,我应该采取什么步骤来解决这个问题?
更新
我通过从php.ini 文件中删除分号来添加驱动程序
extension=php_pdo_oci.dll
但我开始收到此错误。
程序无法启动,因为您的计算机缺少 OCI.dll。尝试重新安装程序以解决此问题。
对于显示的不同警报框,我必须单击 4 次确定。我还下载了oci.dll 并将其复制到windows/system32,但仍然出现此错误。怎么办?
更新
我卸载了 XAMPP 并按照本指南分别安装 Apache 和 PHP,
http://www.oracle.com/technetwork/articles/dsl/technote-php-instant-12c-2088811.html
然后我试试运气。那个驱动问题消失了,但是有新的问题
ERROR: SQLSTATE[HY000]: pdo_oci_handle_factory: ORA-12521: TNS:listener 目前不知道连接描述符中请求的实例 (ext\pdo_oci\oci_driver.c:635)
下面是我的新连接字符串。
try {
$conn = new PDO('oci:dbname=//localhost:1521/xe/ORCL', 'customsearch', 'babaji');
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch(PDOException $e) {
echo 'ERROR: ' . $e->getMessage();
}
我尝试按照 Stack Overflow 上的这个答案创建连接字符串。
http://stackoverflow.com/questions/11970261/connect-oracle-with-pdo-with-sid-and-instance-name
更新 2
还尝试检查是否安装了驱动程序。我用了这段代码
foreach(PDO::getAvailableDrivers() as $driver)
echo $driver, '\n';
从以下链接获取此代码
http://stackoverflow.com/questions/23239433/could-not-connect-to-oracle-using-pdo
它与下面的行相呼应
oci\n
所以这意味着它已安装或这意味着缺少某些驱动程序?
更新 3
再次回滚到旧连接只是更改了该连接中的一些内容,并且似乎与 oracle 的连接有效。
try {
$conn = new PDO("oci:dbname=".$tns, 'customsearch', 'babaji');
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
echo 'Connected to database';
} catch(PDOException $e) {
echo 'ERROR: ' . $e->getMessage();
}
我收到消息“已连接到数据库”,这意味着 echo 有效,因为 PDO 没有给出错误。
但问题是现在我的查询不起作用?我的查询怎么了?还是在连接到 Oracle 时也必须更改查询的语法?还是连接仍然无法正常工作?
【问题讨论】:
-
呃...您不会通过将
oci.dll复制到C:\Windows来安装Oracle Instant Client。从 Oracle 获取完整的软件包并按照说明进行操作。 -
@ÁlvaroG.Vicario 能否提供完整包的链接,以便我下载并尝试解决此问题。
-
你可以从这里得到它:Oracle Instant Client
-
@ÁlvaroG.Vicario 我已经安装了instantclient_12_1,因为它被问到,还更新了我的Qustion,我应该卸载并安装另一个版本的即时客户端吗?
-
我认为很明显您已经安装了适当的 PDO 驱动程序,您只需让 Instant Client 工作即可。我不确定现在可以提供什么建议...