>백엔드 개발 >PHP 튜토리얼 >THINKPHP의 addAll이 지원하는 최대 데이터량에 대해

THINKPHP의 addAll이 지원하는 최대 데이터량에 대해

WBOY
WBOY원래의
2016-08-08 09:30:111132검색

Thinkphp에는 모델 작업을 위한 두 가지 방법이 있습니다: add() 및 addAll

<spanmicrosoft yahei font-size:><span>1</span> <span>$User</span> = M("User"); <span>//</span><span> 实例化User对象</span>
<span>2</span> <span>$data</span>['name'] = 'ThinkPHP'<span>;
</span><span>3</span> <span>$data</span>['email'] = 'ThinkPHP@gmail.com'<span>;
</span><span>4</span> <span>$User</span>->add(<span>$data</span><span>);
</span><span>5</span> 
<span>6</span> <span>$dataList</span>[] = <span>array</span>('name'=>'thinkphp','email'=>'thinkphp@gamil.com'<span>);
</span><span>7</span> <span>$dataList</span>[] = <span>array</span>('name'=>'onethink','email'=>'onethink@gamil.com'<span>);
</span><span>8</span> <span>$User</span>->addAll(<span>$dataList</span>);</spanmicrosoft>

addAll 메소드는 MySQL이 사용되는 방식인 일괄적으로 데이터를 추가할 수 있습니다.

<spanmicrosoft yahei font-size:>INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);</spanmicrosoft>

데이터가 많은 경우 루프에서 항목을 하나씩 삽입하는 대신 일괄 삽입을 시도하세요. 그렇지 않으면 데이터베이스가 과부하되어 중단됩니다.

하지만 이를 당연하게 여기고 모든 데이터를 배열에 저장하고 addAll을 수행하면 역시 끊김 현상이 발생하게 됩니다. 왜 그럴까요?

그 이유는 mysql의 max_allowed_packet 변수 구성이 업로드 SQL 문의 길이를 제한하기 때문입니다. 단지 mysql 구성에서 더 크게 구성하면 됩니다

<spanmicrosoft yahei font-size:>max_allowed_packet = 100M</spanmicrosoft>


동시에 데이터를 삽입할 때 일괄 삽입 길이도 제한해야 합니다. 결국 데이터가 언제 수백만 개가 될지 알 수 없습니다.

위 내용은 관련 내용을 포함하여 THINKPHP의 addAll이 지원하는 최대 데이터 용량을 소개하고 있어 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:ApiGen 4.0 구성 항목다음 기사:ApiGen 4.0 구성 항목