将PDO与Oracle数据库连接 - php

我是Oracle的新手,今天已经安装了Oracle 11g Express Edition。
然后,我安装了Java SDK,然后安装了免费的Oracle SQL Developer。
我连接了系统帐户并创建了如下定义的用户名和表。我不完全了解Oracle的工作原理,我认为使用的是用户名,而不是数据库名。因此,下面是详细信息。

用户名/连接/数据库= CustomSearch
表格= Reservation_General_2

该表中有一些列和一些数据。但关键是我无法连接到Oracle Server。

这是我尝试连接数据库服务器的方式。

<?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

然后我尝试了运气。该驱动程序问题消失了,但是有新问题

错误: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();
}

这样,我得到消息“已连接到数据库”,这意味着回显有效,因为PDO没有给出错误。

但问题是现在我的查询无法正常工作?我的查询怎么了?还是在连接到Oracle时也必须更改查询的语法?还是连接仍然不起作用?

参考方案

检查是否正确安装了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);

将输入类型复选框关联到输入类型文本 - php

我有一个问题,我需要将输入类型复选框与输入类型文本关联。情况如下:从数据库中提取数据。 PK数据是复选框的值。当复选框选择输入类型的文本时,您可以在其中输入特定数字。现在的问题是,选中所有类型的复选框输入文本都会被激活。我希望通过选择复选框输入,仅启用与复选框相关联的输入。我的HTML代码(此代码创建一个输入复选框,并为数据库中的每个记录输入文本,而我要激活…

为什么preg_replace抛出“未知修饰符”错误? - php

我不断收到此错误: 警告:preg_match() [function.preg-match]:未知 修饰语“ t”在 D:\ xampp \ htdocs \ administrator \ components \ com_smms \ functions \ plugin.php 在235行上:$PageContent = preg_replace($…

AJAX调用只能与$(document).on('click')一起使用 - php

我有一个显示数据库条目的表。用户能够为每一行打开一个弹出菜单。选项之一是删除数据库条目,并且该表应通过AJAX调用相应地刷新。只要有人单击#delete-toggle中的table-popup,我就会在HTML页面上进行AJAX调用(table-popup是div,当有人单击每行中存在的表中的table-edit-button时出现的表): <div …

PHP-全局变量的性能和内存问题 - php

假设情况:我在php中运行一个复杂的站点,并且我使用了很多全局变量。我可以将变量存储在现有的全局范围内,例如$_REQUEST['userInfo'],$_REQUEST['foo']和$_REQUEST['bar']等,然后将许多不同的内容放入请求范围内(这将是适当的用法,因为这些数据指的是要求自…

显示基于主类别的子类别不适用于AJAX - php

我的数据库中有一个“ make”和“ model”表。当我回声汽车“制造”时,它可以正常工作。但是,我希望汽车“模型”下拉列表根据选定的“制造商”与ajax一起显示,因此在视图中不起作用但是,我需要的所有信息都显示在控制台的“网络”选项卡上。问题出在哪里?这是我的ajax代码:<script type="text/javascript…