_dbconn = null; } /* [INHERITED DOCS] */ function destroy() { $this->disconnect(); parent::destroy(); } /* [INHERITED DOCS] */ function connect() { if ($this->_dbconn) return true; // XXX may add 'connect_timeout=' option $connect_string = "host='" . addslashes($this->_hostname) . "' " . "port={$this->_portnum} " . "user='" . addslashes($this->_username) . "' " . "password='" . addslashes($this->_password) . "' " . "dbname='" . addslashes($this->_database) . "'"; if (($res = @pg_connect($connect_string, PGSQL_CONNECT_FORCE_NEW)) == false) $this->croak('Database Connection Failure', 'pg_connect: Connection failed. Wrong host/user/pass?', 2); // Most likely we'll be using UTF-8 all over. if (pg_set_client_encoding($res, 'utf8')) $this->croak('encoding failed!', 2); $this->_dbconn = $res; return true; } /* [INHERITED DOCS] */ function disconnect() { if (!$this->_dbconn) return true; if (($ret = @pg_close($this->_dbconn)) == true) $this->_dbconn = null; return $ret; } /* [INHERITED DOCS] */ function beginWork() { // "START TRANSACTION is standard SQL syntax and is the recommended way to start an ad-hoc transaction." return $this->execute('START TRANSACTION'); } /* [INHERITED DOCS] */ function execute($query) { $this->_setLastQuery($query); if ($this->_dbconn === null) $this->connect(); // Auto-connect once. if (($res = @pg_query($this->_dbconn, $query)) === false) $this->croak('Database Data Transfer Failure', "pg_query: " . pg_last_error($this->_dbconn), 2); if (is_bool($res)) return true; return new KjwPgResultSet($res); } /* [INHERITED DOCS] */ function safeQuote($mixed) { if(is_string($mixed)) return "'" . pg_escape_string($mixed) . "'"; return parent::safeQuote($mixed); } /* [INHERITED DOCS] */ function nameQuote($string) { return '`' . str_replace('`', '``', preg_replace("/[\x01-\x1f]/", '', str_replace("\x00", '', $string))) . '`'; } /* [INHERITED DOCS] */ function affectedRows() { return pg_affected_rows($this->_dbconn); } /* [INHERITED DOCS] */ function insertId() { // LASTVAL() is new in postgresql 8.1 return $this->seletAtom('LASTVAL()'); } } ?>