zoukankan      html  css  js  c++  java
  • 让ar执行queryall和queryrow方法返回数组

    让ar执行queryall和queryrow方法返回数组

    <?php
    namespace commoncomponents;
    use CActiveRecord;
    use Yii;
    use CDbConnection;
    use CDbException;
    use commonhelpersConnectionHelper;

    class DBActiveRecord extends CActiveRecord{

        public static $_dbConnections = array();
        
        /**
         * @return 数据配置组
         */
        public static function dbActiveGroup()
        {
            return get_called_class();
        }
        
        public static function model($className=__CLASS__)
        {
            if ($className === __CLASS__ )
            {
                $className = get_called_class();
            }
        
            return parent::model($className);
        }
        
        /**
         * 重写了 CActiveRecord的获取数据库连接,默认从公共配置里面读取连接配置
         *
         * @return CDbConnection the database connection used by active record.
         */
        function getDbConnection()
        {
            $activeGroup = $this->dbActiveGroup();
            if(isset(self::$_dbConnections[$activeGroup]))
            {
                return self::$_dbConnections[$activeGroup];
            }
            else
            {
                $dbConnection = ConnectionHelper::get($activeGroup);
                if( ! empty($dbConnection) && $dbConnection instanceof CDbConnection)
                {
                    self::$_dbConnections[$activeGroup] = $dbConnection;
                    return $dbConnection;
                }
                else
                {
                    throw new CDbException(Yii::t('yii','Active Record requires a "'.$activeGroup.'" CDbConnection application component.'));
                }
            }
        }
        
        /**
         * 获取数据库连接,静态方法
         *
         * @return 数据连接
         */
        public static function getDb()
        {
            $className = get_called_class();
            return ConnectionHelper::get($className::dbActiveGroup());
        }
        
        /**
         * 执行数据库function
         *
         * @return 执行结果
         */
        public static function callFunction($mysqlFunction, array $params=array())
        {
            $className = get_called_class();
            $connection = $className::getDb();
            switch ($connection->driverName)
            {
                case 'mysql':
                    return ConnectionHelper::callMysqlFunction($connection, $mysqlFunction, $params);
                    break;
                default:
                    break;
            }
            return FALSE;
        }
        
        /**
         * 执行存储过程
         *
         * @return 执行结果
         */
        public static function callProcedure($mysqlProcedure, array $params=array())
        {
            $className = get_called_class();
            $connection = $className::getDb();
            switch ($connection->driverName)
            {
                case 'mysql':
                    return ConnectionHelper::callMysqlProcedure($className::getDb(), $mysqlProcedure, $params);
                    break;
                default:
                    break;
            }
            return FALSE;
        }
        
        /**
         * 获取字段rawName加表别名前缀,主要联表时候防止where条件中字段冲突用的
         * @param string $columnName
         * @return string
         */
        public function getColumnRawName($columnName)
        {
            $prefix = $this->getTableAlias(true) . '.';
            $columns = $this->tableSchema->columns;
            if (isset($columns[$columnName]))
            {
                return $prefix.$columns[$columnName]->rawName;
            }
            else
            {
                return $columnName;
            }
        }
        
        /**
         *
         * @param mixed $criteria
         */
        public function queryAll($criteria = NULL)
        {
            if ( ! empty($criteria))
            {
                $this->getDbCriteria()->mergeWith($criteria);
            }
            
            $result = $this->getCommandBuilder()
                ->createFindCommand($this->tableSchema, $this->getDbCriteria())
                ->queryAll();
            
            $this->setDbCriteria(NULL);
            
            return $result;
        }
        
        public function queryRow($criteria = NULL)
        {
            if ($criteria != NULL)
            {
                $this->getDbCriteria()->mergeWith($criteria);
            }
            
            $result = $this->getCommandBuilder()
                ->createFindCommand($this->tableSchema, $this->getDbCriteria())
                ->queryRow();
            
            $this->setDbCriteria(NULL);
            
            return $result;
        }
        
        public function compare($column, $value, $partialMatch = FALSE, $operator = 'AND')
        {
            $criteria = new CDbCriteria;
            $column = $this->getColumnRawName($column);
            
            if ($value === array())
            {
                $criteria->condition = "1 = 0";
            }
            else if ($value === '')
            {
                $criteria->condition = $column." = ''";
            }
            else
            {
                $criteria->compare($column, $value, $partialMatch, $operator, TRUE);
            }
            
            $this->getDbCriteria()->mergeWith($criteria);
            
            return $this;
        }
        
        
    }

  • 相关阅读:
    阿里HBase高可用8年“抗战”回忆录
    Service Mesh 初体验
    阿里云HBase推出普惠性高可用服务,独家支持用户的自建、混合云环境集群
    Ververica Platform-阿里巴巴全新Flink企业版揭秘
    深度 | 带领国产数据库走向世界,POLARDB底层逻辑是什么?
    AI加持的阿里云飞天大数据平台技术揭秘
    Nacos 常见问题及解决方法
    数据上云,应该选择全量抽取还是增量抽取?
    一文带你了解 Flink Forward 柏林站全部重点内容
    Oracle数据库中序列(SEQUENCE)的用法详解
  • 原文地址:https://www.cnblogs.com/jami918/p/3461831.html
Copyright © 2011-2022 走看看