Welcome to mirror list, hosted at ThFree Co, Russian Federation.

BatchInsert.php « Db « Migration « Updater « core - github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 3a3cc1848ac0cc688a622b565e32dfc1a0e11600 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<?php
/**
 * Matomo - free/libre analytics platform
 *
 * @link https://matomo.org
 * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
 */
namespace Piwik\Updater\Migration\Db;

use Piwik\Db;
use Piwik\Updater\Migration;

/**
 * Inserts a new record into an existing table.
 *
 * @see Factory::batchInsert()
 * @see Db\BatchInsert::tableInsertBatch()
 * @ignore
 *
 * We do not extend Migration\Db as it should be not printed to the users in queries preview when updating.
 */
class BatchInsert extends Migration
{
    private $table;
    private $columnNames;
    private $values;
    private $throwException;
    private $charset;

    /**
     * @param string $table
     * @param array $columnNames
     * @param array $values
     * @param bool $throwException
     * @param string $charset
     * @throws \Exception
     */
    public function __construct($table, $columnNames, $values, $throwException, $charset)
    {
        $this->table = $table;
        $this->columnNames = $columnNames;
        $this->values = $values;
        $this->throwException = (bool) $throwException;
        $this->charset = $charset;
    }

    public function shouldIgnoreError($exception)
    {
        return false;
    }

    public function __toString()
    {
        return '<batch insert>';
    }

    public function exec()
    {
        Db\BatchInsert::tableInsertBatch($this->table, $this->columnNames, $this->values, $this->throwException, $this->charset);
    }

    public function getColumnNames()
    {
        return $this->columnNames;
    }

    /**
     * @return string
     */
    public function getTable()
    {
        return $this->table;
    }

    /**
     * @return array
     */
    public function getValues()
    {
        return $this->values;
    }

    /**
     * @return boolean
     */
    public function doesThrowException()
    {
        return $this->throwException;
    }

    /**
     * @return string
     */
    public function getCharset()
    {
        return $this->charset;
    }
}