【问题标题】:Connect PDO with Oracle database将 PDO 与 Oracle 数据库连接
【发布时间】: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 工作即可。我不确定现在可以提供什么建议...

标签: php oracle pdo


【解决方案1】:

检查是否正确安装了 PDO 和 OCI 驱动程序

试试下面的代码

class PDOConnection {

    private $dbh;

    function __construct() {
        try {

            $server         = "127.0.0.1";
            $db_username    = "SYSTEM";
            $db_password    = "Oracle_1";
            $service_name   = "ORCL";
            $sid            = "ORCL";
            $port           = 1521;
            $dbtns          = "(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = $server)(PORT = $port)) (CONNECT_DATA = (SERVICE_NAME = $service_name) (SID = $sid)))";

            //$this->dbh = new PDO("mysql:host=".$server.";dbname=".dbname, $db_username, $db_password);

            $this->dbh = new PDO("oci:dbname=" . $dbtns . ";charset=utf8", $db_username, $db_password, array(
                PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
                PDO::ATTR_EMULATE_PREPARES => false,
                PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC));

        } catch (PDOException $e) {
            echo $e->getMessage();
        }
    }

    public function select($sql) {
        $sql_stmt = $this->dbh->prepare($sql);
        $sql_stmt->execute();
        $result = $sql_stmt->fetchAll(PDO::FETCH_ASSOC);
        return $result;
    }

    public function insert($sql) {
        $sql_stmt = $this->dbh->prepare($sql);
        try {
            $result = $sql_stmt->execute();
        } catch (PDOException $e) {
            trigger_error('Error occured while trying to insert into the DB:' . $e->getMessage(), E_USER_ERROR);
        }
        if ($result) {
            return $sql_stmt->rowCount();
        }
    }

    function __destruct() {
        $this->dbh = NULL;
    }

}

$dbh = new PDOConnection();

$dbh->select($select_sql);
$dbh->insert($insert_sql);

【讨论】:

    【解决方案2】:

    您是否安装了 PDO 驱动程序?查看phpinfo() 的输出,了解您的环境中安装和/或启用的内容。

    PDO Installation

    如果您在 linux 上运行 PHP,您可以通过运行 yum list php-pdo 查看可用于您的发行版的 PDO 驱动程序。您可以通过运行yum install php-pdo 来安装驱动程序。您可能还需要为您的数据库安装特定于数据库的驱动程序。运行yum list php* 将显示所有可供安装的 PHP 扩展。

    Database Specific Drivers

    【讨论】:

    • 感谢您的回复,好的,我通过从 php.ini extension=php_pdo_oci.dll 中删除分号添加了驱动程序但我开始收到此错误。 The program can't start because OCI.dll is missing from your computer. Try reinstalling the program to fix this problem. 我必须单击 4 次确定才能显示不同的警报框。我还下载了 oci.dll 并将其复制到 windows/system32,但仍然出现此错误。怎么办?
    • Windows 是 Windows,您可能需要重新启动服务器才能使配置更改生效。如果您确定已将驱动程序下载并安装在正确的位置,请尝试重新启动。事实上,显然它无法看到/找到驱动程序。当然,请阅读 PHP 手册中的 Windows 安装说明,以确保您已正确完成所有操作。
    【解决方案3】:

    您需要在 Windows 上安装即时客户端,我使用它并且它可以工作,看这个视频,唯一的变化是在他执行安装时的视频中,你不必因为在新的 zip 中,没有' t 有执行文件。我只在进行 SELECT 查询时遇到问题,但连接工作正常。

    https://www.youtube.com/watch?v=cZDDI9HFBIU

    有问题可以联系我

    【讨论】:

      【解决方案4】:

      我认为您的问题出在 oracle 侦听器配置上,您的驱动程序正常,错误“侦听器当前不知道 inst..”表示存在 oracle 配置问题。您必须确保侦听器文件中的参数与连接字符串中的参数完全相同。

      另外你的连接字符串 oci:dbname=//localhost:1521/xe/ORCL 不正确,它应该是 oci:dbname=//localhost:1521/orcl (host:port/service_name) 如 listener.ora 所示文件。使用 SQL developer 确保连接字符串的正确性。

      您可以查看以下链接,该链接说明了 listener.ora 和连接字符串参数的匹配,并且末尾有 php pdo 代码 sn-p 以及连接字符串的正确用法。

      https://www.youtube.com/watch?v=pMQXVihgrrE

      https://adhoctuts.com/fix-oracle-io-error-the-network-adapter-could-not-establish-the-connection-error/

      【讨论】:

        【解决方案5】:

        错,错,错。

        PHPinfo() 不会启用 PDO 驱动程序,也不会显示。

        您无需单独下载 PDO 驱动程序,与您的 PHP 安装一起打包的驱动程序可以正常工作。

        您不需要安装即时客户端,因为您的 PHP for windows 将内置即时客户端。

        解决方案: 使用 PHP 管理器更新 IIS7 或更新安装中的 PHP ini 文件以启用 DLL。

        extension=php_pdo_mysql.dll
        extension=php_pdo_sqlite.dll
        extension=php_pdo_sqlsrv.dll
        [PHP_PDO_OCI]
        extension=php_pdo_oci.dll
        

        都是关于 DLL 的人!

        @Shailesh Sonare 感谢您提供出色的 PDO 连接课程

        还请注意:PDO 即将被弃用 Oracle 推荐 OCI8,因此您无论如何都不应该使用 PDO! ** 编辑过时的手册,但答案仍然正确!

        【讨论】:

        • PDO 没有被弃用。
        • 看看手册中的第 29 页“PDO 扩展和 PDO_OCI 驱动程序是开源的,并包含在 PHP 5.1 及更高版本中。Oracle 不对 PDO_OCI 做出贡献。PHP 社区已经让 PDO 项目萎靡不振Oracle 建议尽可能使用 OCI8,因为它具有更好的特性集、性能、可靠性和稳定性。不建议将 PDO_OCI 用于通用应用程序。 oracle.com/technetwork/database/database-technologies/php/…
        • 看看那本书上的日期。事情发生了变化,Oracle 现在确实为 PDO_OCI 做出了贡献。它没有被弃用。
        • 好吧,也许来源已经过时了,但为什么要投反对票?答案是正确的,只要您引用正确的 DLL 一切正常
        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2016-04-02
        • 2012-11-22
        • 1970-01-01
        • 1970-01-01
        • 2018-05-10
        • 1970-01-01
        • 2011-09-12
        相关资源
        最近更新 更多