NOTICE: Undefined index: MYSQL_DB in /data1/www/htdocs/569/speedphp/1/protected/lib/speed.php on line 329

490.      $msg "ERROR";
491.      if($errno == E_WARNING)$msg "WARNING";
492.      if($errno == E_NOTICE)$msg "NOTICE";
493.      if($errno == E_STRICT)$msg "STRICT";
494.      if($errno == 8192)$msg "DEPRECATED";
495.      err("$msg$errstr in $errfile on line $errline");
496.  }
497.  function err($msg){
498.      $msg htmlspecialchars($msg);
499.      $traces debug_backtrace();
500.      if(!$GLOBALS['debug']){
324.      }
325.      
326.      public function dbInstance($db_config$db_config_key$force_replace false){
327.          if($force_replace || empty($GLOBALS['mysql_instances'][$db_config_key])){
328.              try {
329.                  $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'].'\''));
330.              }catch(PDOException $e){err('Database Err: '.$e->getMessage());}
331.          }
332.          return $GLOBALS['mysql_instances'][$db_config_key];
333.      }
334.      
298. 
299.          if($readonly && !empty($GLOBALS['mysql']['MYSQL_SLAVE'])){
300.              $slave_key array_rand($GLOBALS['mysql']['MYSQL_SLAVE']);
301.              $sth $this->dbInstance($GLOBALS['mysql']['MYSQL_SLAVE'][$slave_key], 'slave_'.$slave_key)->prepare($sql);
302.          }else{
303.              $sth $this->dbInstance($GLOBALS['mysql'], 'master')->prepare($sql);
304.          }
305.          
306.          if(is_array($params) && !empty($params)){
307.              foreach($params as $k => &$v){
308.                  if(is_int($v)){
84.          $sql "DELETE FROM test_user WHERE username = :username";
85.          
86.          // 同query,execute第一个参数是SQL语句,第二个参数是绑定参数的列表
87.          $this->result $user->execute($sql, array(
88.                  ":username" => $username// 注意这种绑定参数的做法,可以防止SQL注入
89.          ));
90.          // execute返回参数和create等相同,即是影响行数,为0则证明没有做任何的修改
91.          
92.          
93.          $this->findall $user->findAll();
94.          $this->display("db/execute.html");
75.  if(!is_available_classname($__controller))_err_router("Err: Controller '$controller_name' is not correct!");
76.  if(!class_exists($controller_nametrue))_err_router("Err: Controller '$controller_name' is not exists!");
77.  if(!method_exists($controller_name$action_name))_err_router("Err: Method '$action_name' of '$controller_name' is not exists!");
78. 
79.  $controller_obj = new $controller_name();
80.  $controller_obj->$action_name();
81. 
82.  if($controller_obj->_auto_display){
83.      $auto_tpl_name = (empty($__module) ? '' $__module.DS).$__controller.'_'.$__action.'.html';
84.      if(file_exists(APP_DIR.DS.'protected'.DS.'view'.DS.$auto_tpl_name))$controller_obj->display($auto_tpl_name);
85.  }
1.  <?php
2.  define('APP_DIR'realpath('./'));
3.  require(APP_DIR.'/protected/lib/speed.php');