Oracle.php 4.78 KB
Newer Older
zYne's avatar
zYne committed
1
<?php
lsmith's avatar
lsmith committed
2
/*
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
 *  $Id$
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * This software consists of voluntary contributions made by many individuals
 * and is licensed under the LGPL. For more information, see
 * <http://www.phpdoctrine.com>.
 */
Doctrine::autoload('Doctrine_Connection');
zYne's avatar
zYne committed
22
/**
23 24
 * Doctrine_Connection_Oracle
 *
25
 * @package     Doctrine
26
 * @subpackage  Connection
27 28 29 30 31 32
 * @license     http://www.opensource.org/licenses/lgpl-license.php LGPL
 * @link        www.phpdoctrine.com
 * @since       1.0
 * @version     $Revision$
 * @author      Konsta Vesterinen <kvesteri@cc.hut.fi>
 */
lsmith's avatar
lsmith committed
33 34
class Doctrine_Connection_Oracle extends Doctrine_Connection
{
35 36 37
    /**
     * @var string $driverName                  the name of this connection driver
     */
38
    protected $driverName = 'Oracle';
lsmith's avatar
lsmith committed
39

lsmith's avatar
lsmith committed
40 41
    public function __construct(Doctrine_Manager $manager, $adapter)
    {
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
        $this->supported = array(
                          'sequences'            => true,
                          'indexes'              => true,
                          'summary_functions'    => true,
                          'order_by_text'        => true,
                          'current_id'           => true,
                          'affected_rows'        => true,
                          'transactions'         => true,
                          'savepoints'           => true,
                          'limit_queries'        => true,
                          'LOBs'                 => true,
                          'replace'              => 'emulated',
                          'sub_selects'          => true,
                          'auto_increment'       => false, // implementation is broken
                          'primary_key'          => true,
                          'result_introspection' => true,
                          'prepared_statements'  => true,
                          'identifier_quoting'   => true,
                          'pattern_escaping'     => true,
                          );
62
        /**
63 64 65 66 67 68 69
        $this->options['DBA_username'] = false;
        $this->options['DBA_password'] = false;
        $this->options['database_name_prefix'] = false;
        $this->options['emulate_database'] = true;
        $this->options['default_tablespace'] = false;
        $this->options['default_text_field_length'] = 2000;
        $this->options['result_prefetching'] = false;
70
        */
zYne's avatar
zYne committed
71
        parent::__construct($manager, $adapter);
zYne's avatar
zYne committed
72
    }
73 74
    /**
     * Sets up the date/time format
zYne's avatar
zYne committed
75
     *
76
     */
zYne's avatar
zYne committed
77 78 79
    public function setDateFormat($format = 'YYYY-MM-DD HH24:MI:SS')
    {
      $this->exec('ALTER SESSION SET NLS_DATE_FORMAT = "' . $format . '"');
80
    }
zYne's avatar
zYne committed
81 82 83
    /**
     * Adds an driver-specific LIMIT clause to the query
     *
84 85 86 87
     * @param string $query         query to modify
     * @param integer $limit        limit the number of rows
     * @param integer $offset       start reading from given offset
     * @return string               the modified query
zYne's avatar
zYne committed
88
     */
lsmith's avatar
lsmith committed
89 90
    public function modifyLimitQuery($query, $limit, $offset)
    {
91
        /**
zYne's avatar
zYne committed
92 93 94
        $e      = explode("select ",strtolower($query));
        $e2     = explode(" from ",$e[1]);
        $fields = $e2[0];
95
        */
zYne's avatar
zYne committed
96 97
        $limit = (int) $limit;
        $offset = (int) $offset;
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
        if (preg_match('/^\s*SELECT/i', $query)) {
            if ( ! preg_match('/\sFROM\s/i', $query)) {
                $query .= " FROM dual";
            }
            if ($limit > 0) {
                // taken from http://svn.ez.no/svn/ezcomponents/packages/Database
                $max = $offset + $limit;
                if ($offset > 0) {
                    $min = $offset + 1;
                    $query = 'SELECT * FROM (SELECT a.*, ROWNUM dctrn_rownum FROM (' . $query
                           . ') a WHERE ROWNUM <= ' . $max . ') WHERE dctrn_rownum >= ' . $min;
                } else {
                    $query = 'SELECT a.* FROM (' . $query .') a WHERE ROWNUM <= ' . $max;
                }
            }
        }
zYne's avatar
zYne committed
114 115
        return $query;
    }
116
}