Пакетная вставка PHP CodeIgniter не принимает мой массив - PullRequest
0 голосов
/ 21 сентября 2011

Я не могу заставить работать следующий код, и он как-то связан с формированием массива. Массив фактически создается после того, как цикл foreach () запускается несколько раз, затем я хочу выполнить пакетную вставку, но он искажен. Почему?

    foreach ($results as $r) {
$insert_array = array(
                            'ListingRid' => $r['ListingRid'],
                            'StreetNumber' => $r['StreetNumber'],
                            'StreetName' => $r['StreetName'],
                            'City' => $r['City'],
                            'State' => $r['State'],
                            'ZipCode' => $r['ZipCode'],
                            'PropertyType' => $r['PropertyType'],
                            'Bedrooms' => $r['Bedrooms'],
                            'Bathrooms' => $r['Bathrooms'],
                            'YearBuilt' => (2011 - $r['Age']),
                            'Status' => $r['Status'],
                            'PictureCount' => $r['PictureCount'],
                            'SchoolDistrict' => $r['SchoolDistrict'],
                            'ListedSince' => $r['EntryDate'],
                            'MarketingRemarks' => $r['MarketingRemarks'],
                            'PhotoUrl' => (!empty($photo_url) ? $photo_url : 'DEFAULT'),
                            'ListingAgentFirstName' => $r['ListingAgentFirstName'],
                            'ListingAgentLastName' => $r['ListingAgentLastName'],
                            'ContactPhoneAreaCode1' => (!empty($a['ContactPhoneAreaCode1']) ? $a['ContactPhoneAreaCode1'] : 'DEFAULT'),
                            'ContactPhoneNumber1' => (!empty($a['ContactPhoneNumber1']) ? $a['ContactPhoneNumber1'] : 'DEFAULT'),
                            'ListingOfficeName' => (!empty($r['ListingOfficeName']) ? $r['ListingOfficeName'] : 'DEFAULT'),
                            'OfficePhoneComplete' => (!empty($o['OfficePhoneComplete']) ? $o['OfficePhoneComplete'] : 'DEFAULT'),
                            'last_updated' => date('Y-m-d H:i:s')
                        );

                        $insert[] = $insert_array;

}

                        $this->db->insert_batch('listings', $insert);

Вот ошибки:

Обнаружена ошибка PHP

Серьезность: Предупреждение

Сообщение: array_keys () [function.array-keys]: первый аргумент должен быть массивом

Имя файла: база данных / DB_active_rec.php

Номер строки: 1148

Произошла ошибка PHP

Серьезность: Предупреждение

Сообщение: sort () ожидает, что для параметра 1 задан массив, значение NULL

Имя файла: база данных / DB_active_rec.php

Номер строки: 1149

Есть идеи? Спасибо!

Ответы [ 2 ]

2 голосов
/ 21 сентября 2011

Я сократил ваш код до минимума, и он, кажется, работает.

        $i = 0;
        while ($i <= 10) {

            $insert_array = array(
                                        'code' => 'asd'
            );

            $insert[] = $insert_array;
            $i++;
        }


        $this->db->insert_batch('group', $insert);

Вы должны проверить элементы массива, прокомментировать их все и откомментировать их один за другим, пока выполучил виновника.

1 голос
/ 21 сентября 2011

Похоже, вам нужно обернуть ваш массив во второй массив. Вы должны предоставить массив массивов строк.

$insert_array = array(array(...));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...