From 8e63827c0fcc218e41428c7f325f5f45c840f33f Mon Sep 17 00:00:00 2001 From: Shish Date: Fri, 31 Dec 2010 19:56:28 +0000 Subject: [PATCH] PDO exceptions for error handling --- core/database.class.php | 41 ++++------------------------------------- index.php | 2 +- 2 files changed, 5 insertions(+), 38 deletions(-) diff --git a/core/database.class.php b/core/database.class.php index dc77f687..8fccb158 100644 --- a/core/database.class.php +++ b/core/database.class.php @@ -289,6 +289,7 @@ class Database { } $this->db = new PDO("$db_proto:host=$db_host;dbname=$db_name", $db_user, $db_pass); + $this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); if(isset($cache_dsn) && !empty($cache_dsn)) { $matches = array(); @@ -304,23 +305,7 @@ class Database { $this->cache = new NoCache(); } - if($this->db) { - $this->engine->init($this->db); - } - else { - $version = VERSION; - print " - - - Internal error - Shimmie-$version - - - Internal error: Could not connect to database - - - "; - exit; - } + $this->engine->init($this->db); } /** @@ -328,12 +313,6 @@ class Database { */ public function execute($query, $args=array()) { $result = $this->db->query($query, $args); - if($result === False) { - print "SQL Error: " . $this->db->ErrorMsg(); - print "
Query: $query"; - print "
Args: "; print_r($args); - exit; - } return $result; } @@ -341,13 +320,7 @@ class Database { * Execute an SQL query and return a 2D array */ public function get_all($query, $args=array()) { - $result = $this->db->GetAll($query, $args); - if($result === False) { - print "SQL Error: " . $this->db->ErrorMsg(); - print "
Query: $query"; - print "
Args: "; print_r($args); - exit; - } + $result = $this->db->fetchAll($query, $args); return $result; } @@ -355,13 +328,7 @@ class Database { * Execute an SQL query and return a single row */ public function get_row($query, $args=array()) { - $result = $this->db->GetRow($query, $args); - if($result === False) { - print "SQL Error: " . $this->db->ErrorMsg(); - print "
Query: $query"; - print "
Args: "; print_r($args); - exit; - } + $result = $this->db->fetch($query, $args); if(count($result) == 0) { return null; } diff --git a/index.php b/index.php index 15a4e2c0..d8483295 100644 --- a/index.php +++ b/index.php @@ -84,7 +84,7 @@ try { // connect to the database $database = new Database(); - $database->db->fnExecute = '_count_execs'; + //$database->db->fnExecute = '_count_execs'; // FIXME: PDO equivalent $config = new DatabaseConfig($database);