~patrix-sbs/oraculum/git

« back to all changes in this revision

Viewing changes to models/doctrine/lib/Doctrine/Sequence/Sqlite.php

  • Committer: Patrick Kaminski
  • Date: 2009-09-02 02:33:07 UTC
  • Revision ID: git-v1:943803254fca67bfb4c0374422b1b836b14dc518
Tags: v0.1a
Sending Oraculum Framework v0.1 alpha

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<?php
 
2
/*
 
3
 *  $Id: Sqlite.php 4252 2008-04-19 07:37:53Z jwage $
 
4
 *
 
5
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 
6
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 
7
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 
8
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 
9
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 
10
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 
11
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 
12
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 
13
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
14
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 
15
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
16
 *
 
17
 * This software consists of voluntary contributions made by many individuals
 
18
 * and is licensed under the LGPL. For more information, see
 
19
 * <http://www.phpdoctrine.org>.
 
20
 */
 
21
 
 
22
/**
 
23
 * Doctrine_Sequence_Sqlite
 
24
 *
 
25
 * @package     Doctrine
 
26
 * @subpackage  Sequence
 
27
 * @author      Konsta Vesterinen <kvesteri@cc.hut.fi>
 
28
 * @license     http://www.opensource.org/licenses/lgpl-license.php LGPL
 
29
 * @link        www.phpdoctrine.org
 
30
 * @since       1.0
 
31
 * @version     $Revision: 4252 $
 
32
 */
 
33
class Doctrine_Sequence_Sqlite extends Doctrine_Sequence
 
34
{
 
35
    /**
 
36
     * Returns the next free id of a sequence
 
37
     *
 
38
     * @param string $seqName   name of the sequence
 
39
     * @param bool $onDemand    when true missing sequences are automatic created
 
40
     *
 
41
     * @return integer          next id in the given sequence
 
42
     */
 
43
    public function nextId($seqName, $onDemand = true)
 
44
    {
 
45
        $sequenceName = $this->conn->quoteIdentifier($this->conn->formatter->getSequenceName($seqName), true);
 
46
        $seqcolName   = $this->conn->quoteIdentifier($this->conn->getAttribute(Doctrine::ATTR_SEQCOL_NAME), true);
 
47
 
 
48
        $query        = 'INSERT INTO ' . $sequenceName . ' (' . $seqcolName . ') VALUES (NULL)';
 
49
 
 
50
        try {
 
51
 
 
52
            $this->conn->exec($query);
 
53
 
 
54
        } catch(Doctrine_Connection_Exception $e) {
 
55
            if ($onDemand && $e->getPortableCode() == Doctrine::ERR_NOSUCHTABLE) {
 
56
                // Since we are creating the sequence on demand
 
57
                // we know the first id = 1 so initialize the
 
58
                // sequence at 2
 
59
 
 
60
                try {
 
61
                    $result = $this->conn->export->createSequence($seqName, 2);
 
62
                } catch(Doctrine_Exception $e) {
 
63
                    throw new Doctrine_Sequence_Exception('on demand sequence ' . $seqName . ' could not be created');
 
64
                }
 
65
                // First ID of a newly created sequence is 1
 
66
                return 1;
 
67
            }
 
68
            throw $e;
 
69
        }
 
70
 
 
71
        $value = $this->conn->getDbh()->lastInsertId();
 
72
 
 
73
        if (is_numeric($value)) {
 
74
            $query = 'DELETE FROM ' . $sequenceName . ' WHERE ' . $seqcolName . ' < ' . $value;
 
75
            
 
76
            $this->conn->exec($query);
 
77
            /**
 
78
            TODO: is the following needed ?
 
79
            $this->warnings[] = 'nextID: could not delete previous sequence table values from '.$seq_name;
 
80
            */
 
81
        }
 
82
        return $value;
 
83
    }
 
84
 
 
85
    /**
 
86
     * Returns the autoincrement ID if supported or $id or fetches the current
 
87
     * ID in a sequence called: $table.(empty($field) ? '' : '_'.$field)
 
88
     *
 
89
     * @param   string  name of the table into which a new row was inserted
 
90
     * @param   string  name of the field into which a new row was inserted
 
91
     * @return integer|boolean
 
92
     */
 
93
    public function lastInsertId($table = null, $field = null)
 
94
    {
 
95
        return $this->conn->getDbh()->lastInsertId();
 
96
    }
 
97
 
 
98
    /**
 
99
     * Returns the current id of a sequence
 
100
     *
 
101
     * @param string $seqName   name of the sequence
 
102
     *
 
103
     * @return integer          current id in the given sequence
 
104
     */
 
105
    public function currId($seqName)
 
106
    {
 
107
        $sequenceName = $this->conn->quoteIdentifier($this->conn->formatter->getSequenceName($seqName), true);
 
108
        $seqcolName   = $this->conn->quoteIdentifier($this->conn->getAttribute(Doctrine::ATTR_SEQCOL_NAME), true);
 
109
 
 
110
        $query        = 'SELECT MAX(' . $seqcolName . ') FROM ' . $sequenceName;
 
111
 
 
112
        return (int) $this->conn->fetchOne($query);
 
113
    }
 
114
}
 
 
b'\\ No newline at end of file'