L oop через партию Codeigniter - PullRequest
1 голос
/ 17 апреля 2020

Я вставляю данные в базу данных, используя функцию insert_batch().

Я хочу разделить процесс. Я имею в виду, если я хочу создать 10000 серийных номеров. но по 1000 строк за раз, процесс создания должен запускаться 10 раз в al oop.

Как я могу это сделать?

    $serial_numbers  = $this->serial_numbers_model->generate_serial_numbers($product_id, $partner_id, $serial_number_quantity, $serial_number_start);
    $issued_date     = date("Y-m-d H:i:s");
    $inserted_rows   = 0;

    foreach ($serial_numbers as $sn) {
        $check_number = $this->serial_numbers_model->generate_check_number();
        $first_serial_number = reset($serial_numbers);
        $last_serial_number = end($serial_numbers);
        $inserted_rows++;

        $insert_data[] = array(
            'partner_id'            => $partner_id,
            'product_id'            => $product_id,
            'check_number'          => $check_number,
            'serial_number'         => $sn,
            'issued_time'           => $issued_date,
            'serial_number_status'  => CREATE_STATUS
        );
    }

    $this->serial_numbers_model->insert_batch($insert_data);
}

1 Ответ

1 голос
/ 21 апреля 2020

Вероятно, ваш serial_numbers_model->insert_batch() - это просто оболочка для родного insert_batch() Codeigniter? В приведенном ниже коде для ясности используется собственный код, при необходимости замените его на свой.

// Track how many in your batch, and prepare empty batch array
$count = 0;
$insert_data = [];

foreach ($serial_numbers as $sn) {

    // ... your code, prepare your data, etc ...

    $count++;

    $insert_data[] = array(
        // ... your data ...
    );

    // Do you have a batch of 1000 ready?
    if ($count === 1000) {

        // Yes - insert it
        $this->db->insert_batch('table', $insert_data);
        // $this->serial_numbers_model->insert_batch($insert_data);

        // Reset the count, and empty the batch, ready to start again
        $count = 0;
        $insert_data = [];
    }
}

// Watch out!  If there were 1001 serial numbers, the first 1000 were handled, 
// but the last one hasn't been inserted!
if (sizeof($insert_data)) {
    $this->db->insert_batch('table', $insert_data);
}
...