利用PHP對(duì)數(shù)組賦值時(shí)下標(biāo)變量會(huì)自動(dòng)遞增的特點(diǎn),可以很方便用循環(huán)將數(shù)據(jù)存入一個(gè)數(shù)組。例如:$arr[] = 'a'; 這條語(yǔ)句會(huì)將字符a存入數(shù)組變量$arr中,如果$arr不存在則會(huì)新建一個(gè);若已存在,則將$arr數(shù)組的下標(biāo)變量遞增1后存入字符。也就是說(shuō),如果已有$arr[0]='a', 那么執(zhí)行 $arr[] = 'b'; 后,數(shù)組其實(shí)是進(jìn)行了$arr[1] = 'b' 的操作。
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序定制開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了八步免費(fèi)建站歡迎大家使用!
PHP框架 Laravel Eloquent ORM 批量插入數(shù)據(jù)是通過(guò)傳入數(shù)組實(shí)現(xiàn)的。
比如:
DB::table('users')-insert(array(
array('email' = 'taylor@example.com', 'votes' = 0),
array('email' = 'dayle@example.com', 'votes' = 0),
));
以上是操作表users,執(zhí)行insert語(yǔ)句,參數(shù)是一個(gè)數(shù)組,封裝了兩條數(shù)據(jù),這里可以自定義數(shù)據(jù),insert內(nèi)部就編程批量插入了。
然后調(diào)用save方法:
public static function create(array $attributes)
{
$model = new static($attributes);
$model-save();
return $model;
}
你的代碼沒(méi)了?
你光寫(xiě)出個(gè)sql語(yǔ)句 不執(zhí)行 他怎么可能插入成功?
mysql_query($sql); 寫(xiě)上。。
$query = mysql_query($sql);
if($query){
echo '數(shù)據(jù)插入成功。';
}else{
echo '數(shù)據(jù)插入失敗。';
}
有兩個(gè)方法可供選擇,一種是把數(shù)據(jù)存入csv文件,然后執(zhí)行l(wèi)oad data infile
還有一種就是類似于sql server里面的bulk insert,使用insert語(yǔ)句插入批量數(shù)據(jù),結(jié)合PHP的implode函數(shù),
可以很簡(jiǎn)單的實(shí)現(xiàn)大批量數(shù)組數(shù)據(jù)的一次性插入。
[php] view plaincopy
$statement = "INSERT INTO table (title, type, customer) VALUES ";
foreach( $data as $row) {
$statement .= ' ("' . implode($row, '","') . '")';
}
不過(guò)大批量數(shù)據(jù)的插入,需要注意mysql在內(nèi)存上有限制:
bulk_insert_buffer_size變量的默認(rèn)大小為8M, 是指單個(gè)線程占用的大小限制,設(shè)置為0,表示不做限制。
沒(méi)用框架就直接拼接sql語(yǔ)句啊
$sql = 'insert into tablename(field1, field2, field3) values(val1, val2, val3), (val1, val2,val3)';
主要就是拼接values后面的內(nèi)容,一個(gè)括號(hào)一條數(shù)據(jù),拼接完執(zhí)行數(shù)據(jù)庫(kù)插入操作就行了;
如果數(shù)據(jù)量很大,注意每次拼接的sql不要太長(zhǎng)了,數(shù)據(jù)庫(kù)執(zhí)行的sql也是有長(zhǎng)度限制的