vinoalvino Posted February 12, 2009 Share Posted February 12, 2009 Quando scriviamo un modulo utiliziamo una o più variabili di configurazione per impostare i parametri del modulo stesso. Ogni salvataggio/richiesta di una singola variabile richiede un accesso al Db. Per velocizzare il modulo stesso utilizzo un sistema che vorrei condividere, in quanto consente di ridurre drasticamente il numero delle variabili e, di conseguenza, di accessi al db.Invece di usare una variabile per ogni valore utilizzo una stringa (pseudo-array) nella quale separo ogni singolo valore con il carattere "|". Vediamo come con un esempio.Ho bisogno di 5 variabili; invece di inizializzarne 5 (nella funzione install) ne uso una: Configuration::updateValue('NAVIGATION_SHOW', "1|0|0|1|0" ); Scrivo una piccola funzione che mi legge la variabile: private function getOptions($key, $id_lang = NULL) { /* inizializzo un array vuoto */ $result=array( 'search'=>0, 'category'=>0, 'manufacturer'=>0, 'supplier'=>0, 'cms'=>0, ); /* leggo il valore */ $opt=Configuration::get($key,$id_lang); /* se non trovo la variabile torno l'array vuoto */ if ($opt===false) return $result; /* explode rende un array di valori utilizzando il separatore indicato */ $var=explode("|", $opt); /* assegno le variabili all'array */ $result['search'] =(isset($var[0]) ? intval($var[0]) : 0 ); $result['category'] =(isset($var[1]) ? intval($var[1]) : 0 ); $result['manufacturer']=(isset($var[2]) ? intval($var[2]) : 0 ); $result['supplier'] =(isset($var[3]) ? intval($var[3]) : 0 ); $result['cms'] =(isset($var[4]) ? intval($var[4]) : 0 ); return $result; } La chiamata a questa funzione è: $var=$this->getOptions('NAVIGATION_SHOW'); Ora posso utilizzare le mie variabili con $var['search'] ... Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now