Можно ли вставлять сразу несколько записей с помощью jDatabase?

11

Вместо использования цикла, могут ли функции базы данных Joomla создавать оператор SQL, подобный этому?

INSERT INTO #__tablename (col1,col2)
VALUES 
 ('1', 'one'),
 ('2', 'two'),
 ('3', 'three'),
...
 ('999', 'three'),

Документы в разделе Доступ к базе данных с использованием JDatabase , ссылаются на транзакции и с использованием SQL или объектов, но в обоих случаях не упоминаются множественные значения.

ВВП
источник

Ответы:

12

Это может быть достигнуто с помощью ->insert()и ->values(), $valuesбудучи массивом строк со столбцами для вставки.

$db = JFactory::getDbo();
$query = $db->getQuery(true);

$columns = array('col_one','col_two');
$values = array();
// Proper escaping/quotes should be done here, and probably in a loop, but cluttered the answer, so omitted it
$values[] = '1, "one"';
$values[] = '2, "two"';
$values[] = '3, "three"';
$values[] = '999, "nineninetynine"';

$query->insert($db->quoteName('#__tablename'));
$query->columns($columns);
$query->values($values);
$db->setQuery($query);
$db->query();

SQL, который производится с использованием echo $query->dump()

INSERT INTO `xyz_tablename`
(col_one,col_two) VALUES 
(1, "one"),(2, "two"),(3, "three),(999, "nineninetynine")
ВВП
источник
3

Ядро Joomla поддерживает основные запросы SQL. Вы можете создать класс для хранения нескольких вставок и создать один последний запрос для выполнения одной вставки в конце.

    public function flushInserts()
{
    $db = JFactory::getDbo();

    foreach ($this->bulk_tables as $table)
    {
        // No inserts
        if (!array_key_exists($table, $this->bulk_inserts))
        {
            continue;
        }

        $tableq = $db->qn($table);

        $insertSet = $this->bulk_inserts[$table];
        $values = implode(',', $insertSet);
        $query = 'INSERT INTO ' . $tableq . ' VALUES ' . $values . ';';

        $db->setQuery($query);
        $db->execute();

        if ($error = $db->getErrorMsg())
        {
            throw new Exception($error);
        }
    }

    $this->bulk_inserts = array();
}
Анибал
источник
0

Добавление к ответу @ GDP

...
$columns = array('user_id', 'type', 'object', 'lvl', 'date');
$values  = array();
foreach ($batch as $row) {
    $array    = array(
        $row->user_id,
        $db->quote($row->type),
        $db->quote($row->object),
        $db->quote($row->lvl),
        $db->quote($row->date),
    );
    $values[] = implode(',', $array);
}
$query->insert($db->quoteName('#__activity_log'));
$query->columns($db->quoteName($columns));
$query->values($values);
...
Мохд Абдул Муджиб
источник
Можете ли вы объяснить значение в своем ответе, которое еще не охвачено принятым ответом @ GDP? Это почти кодовый ответ.
mickmackusa
Он показывает, как заполнить $valuesпеременную массивом comma separated row stringsпрограммно, что экономит много времени и имеет меньший запас для ошибок, а не создает вручную строки, разделенные запятыми, как в его ответе, или даже объединяет в этом отношении.
Мохд Абдул Муджиб
Эта информация должна быть включена в ваш ответ, чтобы она могла помочь будущим исследователям.
mickmackusa
Что ж, я так понимаю, при условии, что код довольно понятен, хотя, безусловно, могут быть области для улучшения, если вы так думаете, пожалуйста, не стесняйтесь редактировать и улучшать ответ
Мохд Абдул Муджиб
Ваш код не требует пояснений для тех, кто понимает, что означает синтаксис php / Joomla. Вам не нравится улучшать свою собственную работу? На JSX (больше, чем Stackoverflow) полное объяснение ответов очень важно, потому что люди, которые только начинают карьеру в веб-разработке, соблазняются сделать это CMS. Вы понимаете, что смысл размещать контент здесь - обучать, верно? Я имею в виду, я призываю вас опубликовать свой лучший ответ и рискует получить положительные отзывы.
mickmackusa