| | |
| | | public $errorMessage = ''; // last error message |
| | | private $errorLocation = '';// last error location |
| | | public $show_error_messages = false; // false in server, true in interface |
| | | private $isConnected = false; // needed to know if we have a valid mysqli object from the constructor |
| | | |
| | | // constructor |
| | | public function __construct($host = NULL , $user = NULL, $pass = NULL, $database = NULL) { |
| | |
| | | $this->dbClientFlags = $conf['db_client_flags']; |
| | | |
| | | parent::__construct($this->dbHost, $this->dbUser, $this->dbPass,$this->dbName); |
| | | if ($this->connect_error) { |
| | | $try = 0; |
| | | while(!is_null($this->connect_error) && $try < 10) { |
| | | if($try > 8) sleep(5); |
| | | elseif($try > 0) sleep(1); |
| | | |
| | | $try++; |
| | | $this->updateError('DB::__construct'); |
| | | } else { |
| | | $this->setCharacterEncoding(); |
| | | |
| | | parent::__construct($this->dbHost, $this->dbUser, $this->dbPass,$this->dbName); |
| | | } |
| | | |
| | | if(is_null($this->connect_error)) $this->isConnected = true; |
| | | |
| | | $this->setCharacterEncoding(); |
| | | } |
| | | |
| | | public function __destruct() { |
| | |
| | | public function updateError($location) { |
| | | global $app; |
| | | |
| | | if($this->connect_error) { |
| | | if(!is_null($this->connect_error)) { |
| | | $this->errorNumber = $this->connect_errno; |
| | | $this->errorMessage = $this->connect_error; |
| | | } else { |
| | |
| | | } |
| | | |
| | | private function setCharacterEncoding() { |
| | | if($this->isConnected == false) return false; |
| | | parent::query( 'SET NAMES '.$this->dbCharset); |
| | | parent::query( "SET character_set_results = '".$this->dbCharset."', character_set_client = '".$this->dbCharset."', character_set_connection = '".$this->dbCharset."', character_set_database = '".$this->dbCharset."', character_set_server = '".$this->dbCharset."'"); |
| | | } |
| | | |
| | | public function query($queryString) { |
| | | if($this->isConnected == false) return false; |
| | | $try = 0; |
| | | do { |
| | | $try++; |
| | | $ok = parent::ping(); |
| | | $ok = $this->ping(); |
| | | if(!$ok) { |
| | | if(!parent::real_connect($this->dbHost, $this->dbUser, $this->dbPass,$this->dbName)) { |
| | | if(!$this->real_connect($this->dbHost, $this->dbUser, $this->dbPass, $this->dbName)) { |
| | | if($try > 9) { |
| | | $this->updateError('DB::query -> reconnect'); |
| | | return false; |
| | | } else { |
| | | sleep(1); |
| | | sleep(($try > 7 ? 5 : 1)); |
| | | } |
| | | } else { |
| | | $this->setCharacterEncoding(); |
| | |
| | | |
| | | // gibt Array mit Tabellennamen zur�ck |
| | | public function getTables($database_name = '') { |
| | | |
| | | if($this->isConnected == false) return false; |
| | | if($database_name == '') $database_name = $this->dbName; |
| | | $result = parent::query("SHOW TABLES FROM $database_name"); |
| | | for ($i = 0; $i < $result->num_rows; $i++) { |