php读取txt文件并将数据插入到数据库

今天测试一个功能,需要往数据库中插入一些原始数据,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教程有兴趣的朋友有所帮助。

Posted in 未分类

发表评论