sql >> Database >  >> RDS >> Mysql

batch vervangen in voor CodeIgniter Active Record

Als je mijn repository wilt klonen ik heb uitgevoerd. Ik heb het geprobeerd om de oplossing in de hoofdtak te krijgen, maar het lijkt erop dat narfbg er onvermurwbaar tegen is. Misschien zou wat meer deelname van de gemeenschap het geïmplementeerd kunnen krijgen.

/**
 * Replace_Batch
 *
 * Compiles batch insert strings replacing any existing rows and runs the queries
 *
 * @param   string  $table  Table to replace insert into
 * @param   array   $set    An associative array of insert values
 * @param   bool    $escape Whether to escape values and identifiers
 * @return  int Number of rows inserted or FALSE on failure
 */
public function replace_batch($table, $set = NULL, $escape = NULL, $batch_size = 100)
{
    if ($set === NULL)
    {
        if (empty($this->qb_set))
        {
            return ($this->db_debug) ? $this->display_error('db_must_use_set') : FALSE;
        }
    }
    else
    {
        if (empty($set))
        {
            return ($this->db_debug) ? $this->display_error('replace_batch() called with no data') : FALSE;
        }

        $this->set_insert_batch($set, '', $escape);
    }

    if (strlen($table) === 0)
    {
        if ( ! isset($this->qb_from[0]))
        {
            return ($this->db_debug) ? $this->display_error('db_must_set_table') : FALSE;
        }

        $table = $this->qb_from[0];
    }

    // Batch this baby
    $affected_rows = 0;
    for ($i = 0, $total = count($this->qb_set); $i < $total; $i += $batch_size)
    {
        if ($this->query($this->_replace_batch($this->protect_identifiers($table, TRUE, $escape, FALSE), $this->qb_keys, array_slice($this->qb_set, $i, $batch_size))))
        {
            $affected_rows += $this->affected_rows();
        }
    }

    $this->_reset_write();
    return $affected_rows;
}

// --------------------------------------------------------------------

/**
 * Replace batch statement
 *
 * Generates a platform-specific insert string from the supplied data.
 *
 * @param   string  $table  Table name
 * @param   array   $keys   INSERT keys
 * @param   array   $values INSERT values
 * @return  string
 */
protected function _replace_batch($table, $keys, $values)
{
    return 'REPLACE INTO '.$table.' ('.implode(', ', $keys).') VALUES '.implode(', ', $values);
}

Hierboven staat exact dezelfde code als op Github, zodat de oplossing indexeerbaar is naar stackoverflow.com. Maar helaas is mijn antwoord op stackoverflow beperkt tot 30k tekens, dus ik kan niet de hele commit plakken die ook wijzigingen in db-stuurprogramma's omvat.




  1. heb volgorde van meerdere items

  2. Percentage berekenen binnen de SQL

  3. Lijst met gebruikers die toegang hebben tot de database

  4. Postgres-query om te controleren of een string een getal is