今天测试一个功能,需要往数据库中插入一些原始数据,pm给了一个txt文件,如何快速的将这个txt文件的内容拆分为所要的数组,然后再插入到数据库中?
serial_number.txt的示例内容:
serial_number.txt:
dm00001a11 0116,
sn00002a11 0116,
ab00003a11 0116,
pv00004a11 0116,
oc00005a11 0116,
ix00006a11 0116,
创建数据表:
create table serial_number(
id int primary key auto_increment not null,
serial_number varchar(50) not null
)engine=innodb default charset=utf8;
php代码如下:
$conn = mysql_connect(‘127.0.0.1′,’root’,”) or die(“invalid query: ” . mysql_error());
mysql_select_db(‘test’, $conn) or die(“invalid query: ” . mysql_error());
$content = file_get_contents(“serial_number.txt”);
$c//explode()函数以”,”为标识符进行拆分
foreach ($contents as $k => $v)//遍历循环
{
$id = $k;
$serial_number = $v;
mysql_query(“insert into serial_number (`id`,`serial_number`)
values(‘$id’,’$serial_number’)”);
}
备注:方法有很多种,我这里是在拆分txt文件为数组后,然后遍历循环得到的数组,每循环一次,往数据库中插入一次。
再给大家分享一个支持大文件导入的
//*/ — 数据表结构:
— 100000_insert,1000000_insert
create table `100000_insert` (
`id` int(11) not null auto_increment,
`parentid` int(11) not null,
`name` varchar(255) default null,
primary key (`id`)
) engine=innodb auto_increment=1 default charset=utf8
100000 (10万)行插入:insert 100000_line_data use 2.5534288883209 seconds
1000000(100万)行插入:insert 1000000_line_data use 19.677318811417 seconds
//可能报错:mysql server has gone away
//解决:修改my.ini/my.cnf max_allowed_packet=20m
以上就介绍了php读取txt文件并将数据插入到数据库,包括了方面的内容,希望对php教程有兴趣的朋友有所帮助。