ホームページ > php教程 > PHP源码 > CI 批量插入数据

CI 批量插入数据

PHP中文网
リリース: 2016-05-25 17:00:19
オリジナル
1247 人が閲覧しました

CI 批量插入数据的优化算法

$sub_form = array();
		$loop = 0;
		$ins_loop = 0;
		$sum = count($form_datas);
		$this->logger->info('insert data total:'.$sum);
		//使用事物批量导入有助于提高插入效率
		$callStartTime = microtime(true);
		$this->db->trans_start();
		foreach ( $form_datas as $item ) {
        	$loop ++;
        	$sub_form[] = $item;
        	if(($loop % 200) == 0 || $loop == $sum){
        		$this->logger->info('insert data num:'.$loop);
				$res = $this->kb_object_instance_mdl->insert_batch($sub_form,$obj_id);
				$ins_loop ++;
				unset($sub_form);
				if(($ins_loop % 5) == 0){
					$this->logger->info('insert data trans_complete ins_loop:'.$ins_loop);
        			$this->db->trans_complete();
        			if($loop != $sum){
	        			$this->db->trans_start();
	        		}
				}
        	}
		}
		//$this->db->trans_complete();
		$callEndTime = microtime(true);
		$callTime = $callEndTime - $callStartTime;
		$this->logger->info('insert data use time:'.sprintf('%.4f',$callTime));
    	if($this->db->trans_status() === TRUE){
    		$this->_show_msg('1',array('data'=>'import ok'));
    	}else{
    		$this->_show_error('saveOrUpdate error');
    	}
ログイン後にコピー
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート