Zend FR

Consultez la FAQ sur le ZF avant de poster une question

Vous n'êtes pas identifié.

#1 11-02-2014 15:46:32

Khleo
Nouveau membre
Date d'inscription: 06-02-2013
Messages: 9

Profiler mes requêtes SQL

Soit mon modèle suivant :

Code:

class Application_Model_Tdocument extends Zend_Db_Table_Abstract {

    protected $_name = 'document';
    protected $_primary = 'id';

    public function init () {

        $profileur = $this->getAdapter()->getProfiler();
        $profileur->setEnabled(true);

        $this->profiler = $profileur;

        $this->config_vars = Zend_Registry::get('config_vars');

    }

    public function getDocument ($pRefDoc, $pUserID) {

        try {

            $query = "
            SELECT id, ref
            FROM document
            WHERE companyId = 1";

            $return = $this->getAdapter()->fetchAll($query, null, Zend_Db::FETCH_OBJ);

            var_dump(__METHOD__.': '.round($this->profiler->getLastQueryProfile()->getElapsedSecs()*1000, 4).' ms');

            return $return;

        } catch (Zend_Db_Exception $e) {

            Zend_Controller_Action_HelperBroker::getStaticHelper('Log')->queryLog($e->getMessage(), $query, __FILE__, __LINE__, __METHOD__, $_SERVER["REMOTE_ADDR"]);

        }
        
    }

}

qui me retourne

string(51) "Application_Model_Tdocument::getDocument: 0.0799 ms"

lorsque je l'utilise.

Ce qui me permet ensuite de logguer mes méthodes/temps d'exécution dans un fichier afin de suivre le temps d'exécution de chacune de mes méthodes.

J'aimerai savoir si c'est possible d'obtenir le même résultat sans avoir à toucher à ma mèthode, afin qu'elle soit la plus simple possible :

Code:

public function getDocument ($pRefDoc, $pUserID) {

        try {

            $query = "
            SELECT id, ref
            FROM document
            WHERE companyId = 1";

            return $this->getAdapter()->fetchAll($query, null, Zend_Db::FETCH_OBJ);

        } catch (Zend_Db_Exception $e) {

            Zend_Controller_Action_HelperBroker::getStaticHelper('Log')->queryLog($e->getMessage(), $query, __FILE__, __LINE__, __METHOD__, $_SERVER["REMOTE_ADDR"]);

        }
        
    }

J'ai cherché du coté de postDispatch() mais ça semble être réservé pour les contrôleurs. De plus, il faut que je puisse identifier ma methode via __METHOD__

Des idées ?

Hors ligne

 

Pied de page des forums

Propulsé par PunBB
© Copyright 2002–2005 Rickard Andersson
Traduction par punbb.fr

Graphisme réalisé par l'agence Rodolphe Eveilleau
Développement par Kitpages