PDOStatement.php 3.75 KB
Newer Older
romanb's avatar
romanb committed
1
<?php
2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * 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
Benjamin Eberlei's avatar
Benjamin Eberlei committed
16
 * and is licensed under the MIT license. For more information, see
17 18
 * <http://www.doctrine-project.org>.
 */
romanb's avatar
romanb committed
19

20 21
namespace Doctrine\DBAL\Driver;

22 23 24 25 26 27
/**
 * The PDO implementation of the Statement interface.
 * Used by all PDO-based drivers.
 *
 * @since 2.0
 */
28
class PDOStatement extends \PDOStatement implements Statement
29
{
Benjamin Morel's avatar
Benjamin Morel committed
30
    /**
31
     * Protected constructor.
Benjamin Morel's avatar
Benjamin Morel committed
32
     */
33
    protected function __construct()
Benjamin Morel's avatar
Benjamin Morel committed
34 35
    {
    }
36

Benjamin Morel's avatar
Benjamin Morel committed
37 38 39
    /**
     * {@inheritdoc}
     */
40
    public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null)
41 42 43 44 45
    {
        // This thin wrapper is necessary to shield against the weird signature
        // of PDOStatement::setFetchMode(): even if the second and third
        // parameters are optional, PHP will not let us remove it from this
        // declaration.
46
        if ($arg2 === null && $arg3 === null) {
47
            return parent::setFetchMode($fetchMode);
48 49 50
        }

        if ($arg3 === null) {
51
            return parent::setFetchMode($fetchMode, $arg2);
52 53
        }

54
        return parent::setFetchMode($fetchMode, $arg2, $arg3);
55
    }
56 57 58 59

    /**
     * {@inheritdoc}
     */
javer's avatar
javer committed
60
    public function bindValue($param, $value, $type = \PDO::PARAM_STR)
61 62 63 64 65 66 67
    {
        return parent::bindValue($param, $value, $type);
    }

    /**
     * {@inheritdoc}
     */
68
    public function bindParam($column, &$variable, $type = \PDO::PARAM_STR, $length = null, $driverOptions = null)
69
    {
javer's avatar
javer committed
70
        return parent::bindParam($column, $variable, $type, $length, $driverOptions);
71 72 73 74 75 76 77 78 79 80 81 82 83
    }

    /**
     * {@inheritdoc}
     */
    public function execute($params = null)
    {
        return parent::execute($params);
    }

    /**
     * {@inheritdoc}
     */
javer's avatar
javer committed
84
    public function fetch($fetchMode = null, $cursorOrientation = null, $cursorOffset = null)
85
    {
javer's avatar
javer committed
86
        if ($fetchMode === null && $cursorOrientation === null && $cursorOffset === null) {
javer's avatar
javer committed
87 88 89
            return parent::fetch();
        }

javer's avatar
javer committed
90
        if ($cursorOrientation === null && $cursorOffset === null) {
javer's avatar
javer committed
91 92 93 94 95 96 97 98
            return parent::fetch($fetchMode);
        }

        if ($cursorOffset === null) {
            return parent::fetch($fetchMode, $cursorOrientation);
        }

        return parent::fetch($fetchMode, $cursorOrientation, $cursorOffset);
99 100 101 102 103
    }

    /**
     * {@inheritdoc}
     */
javer's avatar
javer committed
104
    public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null)
105
    {
javer's avatar
javer committed
106
        if ($fetchMode === null && $fetchArgument === null && $ctorArgs === null) {
javer's avatar
javer committed
107 108 109
            return parent::fetchAll();
        }

javer's avatar
javer committed
110
        if ($fetchArgument === null && $ctorArgs === null) {
javer's avatar
javer committed
111 112 113
            return parent::fetchAll($fetchMode);
        }

javer's avatar
javer committed
114
        if ($ctorArgs === null) {
javer's avatar
javer committed
115 116 117 118
            return parent::fetchAll($fetchMode, $fetchArgument);
        }

        return parent::fetchAll($fetchMode, $fetchArgument, $ctorArgs);
119 120 121 122 123 124 125 126 127
    }

    /**
     * {@inheritdoc}
     */
    public function fetchColumn($columnIndex = 0)
    {
        return parent::fetchColumn($columnIndex);
    }
128
}