當前位置: 首頁>>代碼示例>>PHP>>正文


PHP DatabaseCompatibilityUtil::bulkInsert方法代碼示例

本文整理匯總了PHP中DatabaseCompatibilityUtil::bulkInsert方法的典型用法代碼示例。如果您正苦於以下問題:PHP DatabaseCompatibilityUtil::bulkInsert方法的具體用法?PHP DatabaseCompatibilityUtil::bulkInsert怎麽用?PHP DatabaseCompatibilityUtil::bulkInsert使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在DatabaseCompatibilityUtil的用法示例。


在下文中一共展示了DatabaseCompatibilityUtil::bulkInsert方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: convertCsvIntoRowsInTable

 protected static function convertCsvIntoRowsInTable($fileHandle, $tableName, $delimiter, $enclosure, $columns)
 {
     assert('gettype($fileHandle) == "resource"');
     assert('is_string($tableName)');
     assert('$tableName == strtolower($tableName)');
     assert('$delimiter != null && is_string($delimiter)');
     assert('$enclosure != null && is_string($enclosure)');
     assert('is_array($columns)');
     $bulkQuantity = 500;
     $importArray = array();
     while (($data = fgetcsv($fileHandle, 0, $delimiter, $enclosure)) !== false) {
         if (count($data) > 1 || count($data) == 1 && trim($data['0']) != '') {
             foreach ($data as $k => $v) {
                 //Convert characterser to UTF-8
                 $currentCharset = mb_detect_encoding($v, $other_charsets = 'UTF-8, UTF-7, ASCII, CP1252, EUC-JP, SJIS, eucJP-win, SJIS-win, JIS, ISO-2022-JP');
                 if (!empty($currentCharset) && $currentCharset != "UTF-8") {
                     $data[$k] = mb_convert_encoding($v, "UTF-8");
                 }
             }
             $importArray[] = $data;
         }
         if (count($importArray) > $bulkQuantity) {
             DatabaseCompatibilityUtil::bulkInsert($tableName, $importArray, $columns, $bulkQuantity);
             $importArray = array();
         }
     }
     if (count($importArray) > $bulkQuantity) {
         throw new NotSupportedException();
     }
     if (count($importArray) > 0) {
         DatabaseCompatibilityUtil::bulkInsert($tableName, $importArray, $columns, $bulkQuantity);
     }
 }
開發者ID:sandeep1027,項目名稱:zurmo_,代碼行數:33,代碼來源:ImportDatabaseUtil.php

示例2: testBulkInsert

 public function testBulkInsert()
 {
     $model = new TestDatabaseBulkInsertModel();
     $model->number = 9999;
     $model->string = 'adasd';
     $model->save();
     $model->delete();
     // Test with different quatations.
     $tableName = TestDatabaseBulkInsertModel::getTableName('TestDatabaseBulkInsertModel');
     $columnNames = array('number', 'string');
     $insertData = array(array(999, 'It\'s string with quatation.'), array(1000, "It\\`s string with quatation."), array(1001, 'It\'s string with "quatation".'));
     DatabaseCompatibilityUtil::bulkInsert($tableName, $insertData, $columnNames, 3);
     $bulkInsertedRows = R::getAll("select * from {$tableName} order by id");
     $this->assertEquals(count($bulkInsertedRows), 3);
     for ($i = 0; $i < 3; $i++) {
         $this->assertEquals($bulkInsertedRows[$i]['number'], $insertData[$i][0]);
         $this->assertEquals($bulkInsertedRows[$i]['string'], $insertData[$i][1]);
     }
     $models = TestDatabaseBulkInsertModel::getAll();
     if (count($models) > 0) {
         foreach ($models as $model) {
             $model->delete();
         }
     }
     // Test when there are less rows of data then bulk quantity for one loop.
     $tableName = TestDatabaseBulkInsertModel::getTableName('TestDatabaseBulkInsertModel');
     $columnNames = array('number', 'string');
     $numberOfRows = 50;
     $bulkQuantity = 100;
     $insertData = $this->createDumpDataForBulkInsert($numberOfRows);
     DatabaseCompatibilityUtil::bulkInsert($tableName, $insertData, $columnNames, $bulkQuantity);
     $bulkInsertedRows = R::getAll("select * from {$tableName} order by id");
     $this->assertEquals(count($bulkInsertedRows), $numberOfRows);
     for ($i = 0; $i < $numberOfRows; $i++) {
         $this->assertEquals($bulkInsertedRows[$i]['number'], $insertData[$i][0]);
         $this->assertEquals($bulkInsertedRows[$i]['string'], $insertData[$i][1]);
     }
     $models = TestDatabaseBulkInsertModel::getAll();
     if (count($models) > 0) {
         foreach ($models as $model) {
             $model->delete();
         }
     }
     // Test when there is much data, for multiple loops of bulk insert.
     $numberOfRows = 520;
     $insertData = $this->createDumpDataForBulkInsert($numberOfRows);
     $bulkQuantity = 100;
     $importDataForOneLoop = array();
     foreach ($insertData as $row) {
         $importDataForOneLoop[] = $row;
         if (count($importDataForOneLoop) > $bulkQuantity) {
             DatabaseCompatibilityUtil::bulkInsert($tableName, $importDataForOneLoop, $columnNames, $bulkQuantity);
             $importDataForOneLoop = array();
         }
     }
     $this->assertFalse(count($importDataForOneLoop) > $bulkQuantity);
     if (count($importDataForOneLoop) > 0) {
         DatabaseCompatibilityUtil::bulkInsert($tableName, $importDataForOneLoop, $columnNames, $bulkQuantity);
     }
     $bulkInsertedRows = R::getAll("select * from {$tableName} order by id");
     $this->assertEquals(count($bulkInsertedRows), $numberOfRows);
     for ($i = 0; $i < $numberOfRows; $i++) {
         $this->assertEquals($bulkInsertedRows[$i]['number'], $insertData[$i][0]);
         $this->assertEquals($bulkInsertedRows[$i]['string'], $insertData[$i][1]);
     }
 }
開發者ID:youprofit,項目名稱:Zurmo,代碼行數:66,代碼來源:DatabaseCompatibilityUtilTest.php

示例3: importArrayIntoTable

 /**
  * Imports data from array to table
  * @param $tableName
  * @param $importArray
  * @param $columnNames
  * @throws NotSupportedException
  */
 protected static function importArrayIntoTable($tableName, array &$importArray, array $columnNames)
 {
     assert('is_string($tableName)');
     assert('$tableName == strtolower($tableName)');
     assert('is_array($columnNames)');
     assert('is_array($importArray)');
     do {
         $importSubset = ArrayUtil::chopArray($importArray, static::BULK_INSERT_COUNT);
         // bulkInsert needs every subarray to have same number of columns as columnNames, pad with empty strings
         static::padSubArrays($importSubset, count($columnNames));
         DatabaseCompatibilityUtil::bulkInsert($tableName, $importSubset, $columnNames, static::BULK_INSERT_COUNT, true);
     } while (count($importSubset) > 0);
 }
開發者ID:maruthisivaprasad,項目名稱:zurmo,代碼行數:20,代碼來源:ImportDatabaseUtil.php


注:本文中的DatabaseCompatibilityUtil::bulkInsert方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。