gpt4 book ai didi

php - 连接 PDO 与 Oracle 数据库

转载 作者:行者123 更新时间:2023-12-02 22:54:23 24 4
gpt4 key购买 nike

我是Oracle新手,今天安装了Oracle 11g Express Edition。然后我安装了 Java SDK,然后安装了免费的 Oracle SQL Developer。我连接了系统帐户并创建了一个用户名和表,如下定义。我不太清楚 Oracle 是如何工作的,我认为使用的是用户名而不是数据库名称。下面是详细信息。

用户名/连接/数据库 = 自定义搜索
表 = 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();
}

问题是当我尝试打开该页面时,出现此错误。

ERROR: could not find driver

这些是我从 Oracle Sql Developer 连接时的连接设置。

enter image description here

我做错了什么,我应该采取什么措施来解决这个问题?

更新

我通过从 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 ,但仍然出现此错误。该怎么办?

更新

我卸载了 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();
}

我尝试按照 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 时,我是否也必须更改查询的语法?或者连接仍然无法正常工作?

最佳答案

检查 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 - 连接 PDO 与 Oracle 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25712045/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com