Database Err: SQLSTATE[HY000] [2002] 由于目标计算机积极拒绝,无法连接。

340.              try {
341.                  if(!class_exists("PDO") || !in_array("mysql",PDO::getAvailableDrivers(), true)){
342.                      err('Database Err: PDO or PDO_MYSQL doesn\'t exist!');
343.                  }
344.                  $GLOBALS['mysql_instances'][$db_config_key] = new PDO('mysql:dbname='.$db_config['MYSQL_DB'].';host='.$db_config['MYSQL_HOST'].';port='.$db_config['MYSQL_PORT'], $db_config['MYSQL_USER'], $db_config['MYSQL_PASS'], array(PDO::MYSQL_ATTR_INIT_COMMAND=>'SET NAMES \''.$db_config['MYSQL_CHARSET'].'\''));
345.              }catch(PDOException $e){err('Database Err: '.$e->getMessage());}
346.          }
347.          return $GLOBALS['mysql_instances'][$db_config_key];
348.      }
349.      
350.      private function _where($conditions){
310. 
311.          if($readonly && !empty($GLOBALS['mysql']['MYSQL_SLAVE'])){
312.              $slave_key array_rand($GLOBALS['mysql']['MYSQL_SLAVE']);
313.              $sth $this->dbInstance($GLOBALS['mysql']['MYSQL_SLAVE'][$slave_key], 'slave_'.$slave_key)->prepare($sql);
314.          }else{
315.              $sth $this->dbInstance($GLOBALS['mysql'], 'master')->prepare($sql);
316.          }
317.          
318.          if(is_array($params) && !empty($params)){
319.              foreach($params as $k => &$v){
320.                  if(is_int($v)){
257.      public function create($row){
258.          $values = array();
259.          foreach($row as $k=>$v){
260.              $keys[] = "`{$k}`"$values[":".$k] = $v$marks[] = ":".$k;
261.          }
262.          $this->execute("INSERT INTO ".$this->table_name." (".implode(', '$keys).") VALUES (".implode(', '$marks).")"$values);
263.          return $this->dbInstance($GLOBALS['mysql'], 'master')->lastInsertId();
264.      }
265.      
266.      public function findCount($conditions){
267.          $conditions $this->_where$conditions );
8.          );
9.          
10.          $user = new User();
11.          
12.          // create返回的是最新插入的自增主键的值
13.          $this->newid $user->create($data);
14. 
15.          
16.          $this->findall $user->findAll();
17.          $this->display("db/create.html");
18.      }
79.  if(!is_available_classname($__controller))_err_router("Err: Controller '$controller_name' is not correct!");
80.  if(!class_exists($controller_nametrue))_err_router("Err: Controller '$controller_name' is not exists!");
81.  if(!method_exists($controller_name$action_name))_err_router("Err: Method '$action_name' of '$controller_name' is not exists!");
82. 
83.  $controller_obj = new $controller_name();
84.  $controller_obj->$action_name();
85. 
86.  if($controller_obj->_auto_display){
87.      $auto_tpl_name = (empty($__module) ? '' $__module.DS).$__controller.'_'.$__action.'.html';
88.      if(file_exists(APP_DIR.DS.'protected'.DS.'view'.DS.$auto_tpl_name))$controller_obj->display($auto_tpl_name);
89.  }
1.  <?php
2.  define('APP_DIR'realpath('./'));
3.  define("APP_PATH",dirname(__FILE__));
4.  require(APP_DIR.'/protected/lib/speed.php');