将PDO与Oracle数据库连接

时间:2014-09-07 15:46:23

标签: php oracle pdo

我是oracle的新手,今天安装了Oracle 11g Express Edition。 然后我安装了Java SDk,然后安装了Free Oracle SQL Developer。 我连接了系统帐户并创建了如下定义的UserName和Table 我不知道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连接时,这些是我的连接设置。 enter image description here

我做错了什么,我应该采取什么措施来解决这个问题并连接到oracle数据库。


更新

我通过从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次OK才能显示不同的警告框。我还下载了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 does not currently know of instance requested in connect descriptor (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();
}

我试图在堆栈溢出时使用这个答案来建立连接字符串。

http://stackoverflow.com/questions/11970261/connect-oracle-with-pdo-with-sid-and-instance-name

有人请解决这个问题。 ___________________________________ ================================================ 的更新

还尝试检查是否安装了驱动程序 我用过这段代码

foreach(PDO::getAvailableDrivers() as $driver)
    echo $driver, '\n';

从以下链接获取此代码

http://stackoverflow.com/questions/23239433/could-not-connect-to-oracle-using-pdo

它回应了以下这一行

oci\n

所以这意味着它已安装或这意味着一些驱动程序丢失了???

============================================== < / p>

更新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();
}

通过这个我收到消息&#39;连接到数据库&#39;,表示echo工作因为PDO没有给出错误。

但问题是现在我的查询不起作用??? 我的查询怎么了?或者,当我连接到oracle时,我是否还要更改查询的语法? 或者连接仍然无法正常工作?

任何人都可以解释?

5 个答案:

答案 0 :(得分:7)

检查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);

答案 1 :(得分:0)

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

PDO Installation

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

Database Specific Drivers

答案 2 :(得分:0)

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

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

如果您有任何疑问,请与我联系

答案 3 :(得分:0)

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

另外,您的连接字符串oci:dbname = // localhost:1521 / xe / ORCL不正确,它应该是oci:dbname = // localhost:1521 / orcl(主机:端口/服务名称),如listener.ora中所示文件。使用SQL Developer确保连接字符串的正确性。

您可以检查以下链接,该链接说明了listener.ora和连接字符串参数的匹配,并且在结尾处有php pdo代码段,其中正确使用了连接字符串。

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

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

答案 4 :(得分:-1)

错误,错误&amp;错误。

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! **编辑过时的手册,但答案仍然正确!