2012-07-01 64 views
1

我使用的是Oracle適配器進行連接到數據庫連接到數據庫,這裏的中的application.ini的配置,錯誤,同時試圖使用Zend Framework

resources.db.adapter = "Oracle" 
resources.db.params.host = "localhost" 
resources.db.params.username = "user" 
resources.db.params.password = "2012" 
resources.db.params.dbname = "books" 
resources.db.isDefaultTableAdapter = true 

在這裏我如何調用存儲過程

$db = Zend_Db_Table::getDefaultAdapter(); 
    try { 
     // $sql = "select * from dual"; 
     $sql = "begin BA_OPERATIONS_PKG.GETMEMBERCRED(" . 
       ":I_USER_ID, :DATA_REC); end;"; 

     $statement = new Zend_Db_Statement_Oracle($db, $sql); 

     $params = array(
      'I_USER_ID' => $userId 
     ); 

     // Create a cursor 
     $cursor = new Zend_Db_Cursor_Oracle($db); 

     // Bind the cursor as a parameter. This SHOULD push a new cursor in the 
     // $_bindCursor stack from Zend_Db_Statement. 
     $statement->bindCursor('DATA_REC', $cursor); 

     $statement->execute($params); 

     echo $cursor; 

    } catch (Exception $e) { 
     print_r($e->getMessage()); 
    } 

這裏的例外,我有

include_once(Zend\Db\Cursor\Oracle.php) [function.include-once]: failed to open stream: No such file or directory in D:\ZendFramework\library\Zend\Loader.php 
+3

Zend Framework中沒有'Zend_Db_Cursor_Oracle'類。我能找到的唯一參考是2009年的這個提案:http://framework.zend.com/wiki/display/ZFPROP/Zend_Db_Cursor+-+Bruno+Piraja+Moyle,但該組件從未將其納入ZF。 –

+0

這是我從中獲取資源的網站。 – palAlaa

+0

你有沒有更好的方法來從orcale接收遊標? – palAlaa

回答

0

我擴展了Oracle適配器,並增加了其實現方法具d:

<?php 

/** 
* @see Zend_Db_Adapter_Pdo_Oci 
*/ 
require_once 'Zend/Db/Adapter/Oracle.php'; 

class Zend_Db_Adapter_Cds extends Zend_Db_Adapter_Oracle 
{ 
    public function fetchCursor($sql, $bind = array()) 
    { 
     $data = array(); 
     $conn = $this->getConnection(); 

     $curs = oci_new_cursor($conn); 
     $stmt = oci_parse($conn, $sql); 

     oci_bind_by_name($stmt, "cursor", $curs, -1, OCI_B_CURSOR); 
     foreach ($bind as $key => &$val) { 
      oci_bind_by_name($stmt, $key, $val, -1, OCI_ASSOC); 
     } 

     oci_execute($stmt); 
     if ($e = oci_error($stmt)) { 
      throw new Zend_Db_Adapter_Oracle_Exception($e, -1234); 
     } 

     oci_execute($curs); 
     if (oci_fetch_all($curs, $data, 0, -1, OCI_FETCHSTATEMENT_BY_ROW)) { 
      ;//var_dump($data); 
     } 

     oci_free_statement($stmt); 
     oci_free_statement($curs); 

     return $data; 
    } 
}