oci_fetch_assoc

(PHP 5, PECL OCI8 >= 1.1.0)

oci_fetch_assocクエリの次の行を連想配列で返す

説明

array oci_fetch_assoc ( resource $statement )

クエリの次の結果セット行を含む連想配列を返します。 配列の各エントリが、カラムに対応します。 この関数の典型的な使い方は、ループの中でコールすることです。 FALSE が返された場合は、もう行がないことをあらわします。

oci_fetch_assoc() をコールするのは、 oci_fetch_array()OCI_ASSOC + OCI_RETURN_NULLS を指定してコールするのと同じです。

パラメータ

statement

oci_parse() で作成して oci_execute() で実行した有効な OCI8 ステートメント ID、 あるいは REF CURSOR ステートメント ID。

返り値

連想配列を返します。 statement にもう行がない場合は FALSE を返します。

例1 oci_fetch_assoc() の例

<?php

$conn 
oci_connect('hr''welcome''localhost/XE');
if (!
$conn) {
    
$e oci_error();
    
trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}

$stid oci_parse($conn'SELECT department_id, department_name FROM departments');
oci_execute($stid);

while ((
$row oci_fetch_assoc($stid)) != false) {
    echo 
$row['DEPARTMENT_ID'] . " " $row['DEPARTMENT_NAME'] . "<br>\n";
}

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

?>

注意

注意:

行の取得例は oci_fetch_array() も参照ください。

参考

  • oci_fetch() - クエリの次の行を内部バッファに取得する
  • oci_fetch_all() - クエリからの複数の行を二次元配列に取得する
  • oci_fetch_array() - クエリの次の行を連想配列あるいは数値添字配列で返す
  • oci_fetch_object() - クエリの次の行をオブジェクトとして返す
  • oci_fetch_row() - クエリの次の行を配列で返す

add a note add a note

User Contributed Notes 3 notes

up
2
dbernhardt129 at gmail dot com
4 years ago
Here's a simple example of using the oci_fetch_assoc function for anyone who would like to see it.

<?php
$oconn
= oci_connect('ora_user','ora_pass','ora_inst');
if (!
$oconn){
 
$msg = "Cannot connect to Oracle ".oci_error();
} else {
 
$msg = "Connected to Oracle";
}

$select_stmt = "select username from user_table";

$stid = oci_parse($oconn, $select_stmt);
oci_execute($stid);

echo
"<table border='1'>\n";

while (
$row = oci_fetch_assoc($stid)) {
    echo
"<tr>\n";
    echo
"<td>". $row["USERNAME"] . "</td>\n";
    echo
"</tr>\n";
}

echo
"</table>\n";

oci_free_statement($stid);
oci_close($oconn);
?>

Make sure you capitalize the column name for referencing the item in the associative array.  Of course, this is just a simple example and you might want to do some processing on the data prior to output, but you get the idea here.
up
0
test at yahoo dot com
2 days ago
<html>
<head>
<?php include("includes/connect.php");?>
<title>Remediëringsoefening</title>
</head>
<body>
<?php
// eerste keuzemenu
$sqlEerste = "SELECT * FROM vakken";
$strResult = $mysqli->query($sqlEerste);
$strAntw1 = "";

while(
$rij=$strResult->fetch_assoc()){
   
$strID = $rij['vakid'];
   
$strVoluit = $rij['voluit'];
   
$strAntw1 .= "<option value='$strID'>$strVoluit</option>";
}
$strKeuze1 = "<select name='Keuze1'><option value='' disabled selected style='display:none;'>Kies vak</option>" . "$strAntw1" . "</select>";
$strForm1 = "<form method='POST'>" . $strKeuze1 . " <input type = 'SUBMIT' value='SUBMIT' name='btnSubmit1'></form>";
echo
$strForm1;

// tweede keuzemenu

if(isset($_POST['btnSubmit1'])){

$vakid = $_POST['Keuze1'];
$sqlTweede = "SELECT * FROM leerkrachten JOIN leerkrachtpervak ON leerkrachten.leerkrachtid = leerkrachtpervak.leerkrachtid WHERE vakid = '$vakid'";
$strResult2 = $mysqli->query($sqlTweede);
$strAntw2 = "";

while(
$rij2=$strResult2->fetch_assoc()){
   
$strID2 = $rij2['leerkrachtid'];
   
$strVoornaam = $rij2['voornaam'];
   
$strAchternaam = $rij2['naam'];
   
$strAntw2 .= "<option value='$strID2'>$strVoornaam $strAchternaam</option>";
}
$strKeuze2 = "<select name='Keuze2'><option value='' disabled selected style='display:none;'>Kies leerkracht</option>" . "$strAntw2" . "</select>";
$strForm2 = $strKeuze2;
echo
$strForm2;

}
?>
</body>
</html>
up
0
Dawid Krysiak
1 year ago
Unlike oci_fetch_all(), after using oci_fetch_assoc(), LOB columns (CLOB, BLOB) are NOT returned as strings but as Oci-Lob objects. You have to use Oci-Lob->read() or load() method in order to read column content.
To Top