今天测试一个功能,需要往数据库中插入一些原始数据,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文件为数组后,然后遍历循环得到的数组,每循环一次,往数据库中插入一次。
再给大家分享一个支持大文件导入的
';}else { echo 'failed!--error:'.array_shift($result).'
';}/*sqlda ta1.txt1|0|a2|1|b3|1|c4|2|d-- cengjicreate table `cengji` ( `id` int(11) not null auto_increment, `parentid` int(11) not null, `name` varchar(255) default null, primary key (`id`), unique key `parentid_name_unique` (`parentid`,`name`) using btree) engine=innodb auto_increment=1602 default charset=utf8*///调用示例2require 'db.php';$splitchar = ' '; //空格$file = 'sqldata2.txt';$fields = array('id','make','model','year');$table = 'cars';$result = loadtxtdataintodatabase($splitchar,$file,$table,$conn,$fields);if (array_shift($result)){ echo 'success!
';}else { echo 'failed!--error:'.array_shift($result).'
';}/* sqldata2.txt11 aston db19 200912 aston db29 200913 aston db39 2009-- carscreate table `cars` ( `id` int(11) not null auto_increment, `make` varchar(16) not null, `model` varchar(16) default null, `year` varchar(16) default null, primary key (`id`)) engine=innodb auto_increment=14 default charset=utf8*///调用示例3require 'db.php';$splitchar = ' '; //tab$file = 'sqldata3.txt';$fields = array('id','make','model','year');$table = 'cars';$inserttype = 'replace';$result = loadtxtdataintodatabase($splitchar,$file,$table,$conn,$fields,$inserttype);if (array_shift($result)){ echo 'success!
';}else { echo 'failed!--error:'.array_shift($result).'
';}/* sqldata3.txt11 aston db19 200912 aston db29 200913 aston db39 2009 *///调用示例3require 'db.php';$splitchar = ' '; //tab$file = 'sqldata3.txt';$fields = array('id','value');$table = 'notexist'; //不存在表$result = loadtxtdataintodatabase($splitchar,$file,$table,$conn,$fields);if (array_shift($result)){ echo 'success!
';}else { echo 'failed!--error:'.array_shift($result).'
';}//附:db.php/* //注释这一行可全部释放?>
//*/
复制代码
-- 数据表结构:
-- 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教程有兴趣的朋友有所帮助。