| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 | <?php/** * @link http://www.yiiframework.com/ * @copyright Copyright (c) 2008 Yii Software LLC * @license http://www.yiiframework.com/license/ */namespace yii\caching;use Yii;use yii\base\InvalidConfigException;use yii\db\Connection;use yii\di\Instance;/** * DbDependency represents a dependency based on the query result of a SQL statement. * * If the query result changes, the dependency is considered as changed. * The query is specified via the [[sql]] property. * * For more details and usage information on Cache, see the [guide article on caching](guide:caching-overview). * * @author Qiang Xue <qiang.xue@gmail.com> * @since 2.0 */class DbDependency extends Dependency{    /**     * @var string the application component ID of the DB connection.     */    public $db = 'db';    /**     * @var string the SQL query whose result is used to determine if the dependency has been changed.     * Only the first row of the query result will be used.     */    public $sql;    /**     * @var array the parameters (name => value) to be bound to the SQL statement specified by [[sql]].     */    public $params = [];    /**     * Generates the data needed to determine if dependency has been changed.     * This method returns the value of the global state.     * @param CacheInterface $cache the cache component that is currently evaluating this dependency     * @return mixed the data needed to determine if dependency has been changed.     * @throws InvalidConfigException if [[db]] is not a valid application component ID     */    protected function generateDependencyData($cache)    {        /* @var $db Connection */        $db = Instance::ensure($this->db, Connection::className());        if ($this->sql === null) {            throw new InvalidConfigException('DbDependency::sql must be set.');        }        if ($db->enableQueryCache) {            // temporarily disable and re-enable query caching            $db->enableQueryCache = false;            $result = $db->createCommand($this->sql, $this->params)->queryOne();            $db->enableQueryCache = true;        } else {            $result = $db->createCommand($this->sql, $this->params)->queryOne();        }        return $result;    }}
 |