繁体   English   中英

为什么使用pdo_oci进行查询比使用oci8更快?

[英]why query execution is faster with pdo_oci than with oci8?

我正在连接到Oracle Database 11g企业版11.2.0.3.0版-64位。

与php 5.6.3(xampp安装)连接。

使用pdo_oci可以立即执行简单的查询。

oci8需要5秒钟。

对于pdo_oci,我使用扩展名php_pdo_oci.dll

对于oci8,我使用扩展名php_oci8_12c.dll

我已经安装了Oracle Instantclient_12_1。

这是pdo_oci的代码:

$hote = '123.456.789.3';
$port = '1521';
$service = 'blabla.blabla-db.blabla';
$user = '12345';
$pass = '12345';

$lien_base =
"oci:dbname=(DESCRIPTION =
(ADDRESS_LIST =
    (ADDRESS =
        (PROTOCOL = TCP)
        (Host = ".$hote .")
        (Port = ".$port."))
)
(CONNECT_DATA =
    (SERVICE_NAME = ".$service.")
)
)";

try
{
    $connexion = new PDO($lien_base, $user, $pass);
}
catch (PDOException $erreur)
{
    echo $erreur->getMessage();
}

$num_notice = "030000002";
$notice = $connexion->query("SELECT * FROM UDQ01.Z13U WHERE Z13U_REC_KEY = ".$connexion->quote($num_notice)."")->fetch();

echo '<pre>' . print_r($notice,1) . '</pre>';

以及oci8的代码:

$conn = oci_connect('12345', '12345', '123.456.211.3:1521/blabla.blabla-db.blabla.ca');
$query = 'SELECT * FROM UDQ01.Z13U WHERE Z13U_REC_KEY = 030000002';
$stid = oci_parse($conn, $query);
oci_execute($stid, OCI_NO_AUTO_COMMIT);

$row = oci_fetch_array($stid, OCI_ASSOC);

echo '<pre>' . print_r($row,1) . '</pre>';

oci_free_statement($stid);
oci_close($conn);

为什么oci8这么慢?

谢谢,

帕特里克

问题出在查询中:

值之间应该有',例如:

$query = "SELECT * FROM UDQ01.Z13U WHERE Z13U_REC_KEY = '030000002'";

'在pdo_oci查询中是隐式的:

"SELECT * FROM UDQ01.Z13U WHERE Z13U_REC_KEY = ".$connexion->quote($num_notice).""

因此pdo_oci和oci8的速度一样快。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM