为什么oci_num_rows总是返回0值?

时间:2013-05-16 09:02:53

标签: php oracle

我有这个问题的代码:

<?php
    include 'connection.php';

    if (oci_execute ( $stmt )) {
        //Execute cursor
        oci_execute($result);  //Or you can return the cursor.
    }


    $count=oci_num_rows($result);
    echo $count;
    if ($count != 1)
    {
    echo $count;
    echo "No record";
    }
    else
    {

   while($objResult = oci_fetch_array($result, OCI_RETURN_NULLS+OCI_ASSOC)){
   <tr>
   <td><div align="center" class="style4"><?php echo $objResult[0]; ?></div></td>
   <td><div align="center" class="style4"><?php echo $objResult[1]; ?></div></td>
   <td><div align="center" class="style4"><?php echo $objResult[2]; ?></div></td>
   <td><div align="center" class="style4"><?php echo $objResult[3]; ?></div></td>
   <td><div align="center" class="style4"><?php echo $objResult[4]; ?></div></td>
    <td><div align="center" class="style4"><?php echo $objResult[5]; ?></div></td>
     <td><div align="center" class="style4"><?php echo $objResult[6]; ?></div></td>
     <td><div align="center" class="style4"><?php echo $objResult[7]; ?></div></td>

     <td><div align="center" class="style4"><a href="updateInsForm.php?insid=<?php echo $objResult[0]; ?>">EDIT</a></div></td>
     <td><div align="center" class="style4"><a href="deleteInsForm.php?insid=<?php echo $objResult[0]; ?>">DELETE</div></td>

    <?php 
   }
   }


   oci_close($objConnect);
 ?>

问题是,当我尝试输入正确的ID和密码时,它将该行返回为0 ..为什么?

1 个答案:

答案 0 :(得分:0)

问题是num_rows函数返回已获取的项目数,而不是执行的结果。来自手册:

http://php.net/manual/en/function.oci-num-rows.php

注意: 此函数不返回选定的行数!对于SELECT语句,此函数将返回使用oci_fetch *()函数提取到缓冲区的行数。

希望这有帮助。

相关问题