我需要帮助才能从包含where子句的select语句中获取行数。我尝试了各种选择。但这对我没有用。我在下面显示了我的代码段。
我收到o / p“读取0行”。但是,当我在Oracle DB上执行select查询时,它将返回1行。
因此,请帮助我通过OCI获取PHP中的select语句数。
环境:
这是Oracle查询
CREATE TABLE users
(
no INTEGER NOT NULL,
id VARCHAR2(200) NOT NULL,
fullname VARCHAR2(200),
email VARCHAR2(200),
givenname VARCHAR2(200),
first_login VARCHAR2(200),
last_login VARCHAR2(200)
);
INSERT INTO USERS (no, id,fullname,email,givenname,first_login,last_login)
VALUES (1,'Bharat','Bharat','Bharat@gmail.com','Bharat','2019-08-20 03:08:42','2019-08-20 03:08:42');
INSERT INTO USERS (no, id,fullname,email,givenname,first_login,last_login)
VALUES (1,'bharat','bharat','bharat@gmail.com','bharat','2019-08-20 03:08:42','2019-08-20 03:08:42');
PHP:
<?php
# connect localhost oracle
$conn = oci_connect('c##admin', 'ibm123', '127.0.0.1/XE');
$res="array"; #array to staore oci_fetch_all o/p
#thow error if unable to make connection
if (!$conn) {
$m = oci_error();
trigger_error(htmlentities($m['message']), E_USER_ERROR);
}
# Parse oracle query
$stid = oci_parse($conn, "select * from users where ID='Bharat'");
# execute statement
oci_execute($stid);
# fetch all content
$nrows = oci_fetch_all($stid, $res);
echo "$nrows rows fetched<br>\n";
# Dump content
var_dump($res);
$numrows = oci_fetch_array($stid, OCI_BOTH);
echo oci_num_rows($stid) . " rows.<br />\n";
print_r($numrows);
oci_free_statement($stid);
oci_close($conn);
?>
这是输出。预期输出为1行。
0 rows fetched
请帮助我解决此问题
答案 0 :(得分:1)
在使用oci_num_rows($stid)之前,您需要使用函数:oci_fetch_all($stid, $out)。