您好,欢迎访问一九零五行业门户网

[新手请问]PHP写入MySQL数据库的有关问题

[新手请教]php写入mysql数据库的问题
现在利用php 数组生成了从1-33的任选6个数字的组合数据,约100万条的数据生成了数据.txt文件,格式如下
[1,2,3,4,5,6]
[1,2,3,4,5,7]
[1,2,3,4,5,8]
[1,2,3,4,5,9]
[1,2,3,4,5,10]
[1,2,3,4,5,11]
[1,2,3,4,5,12]
[1,2,3,4,5,13]
[1,2,3,4,5,14]
[1,2,3,4,5,15]
[1,2,3,4,5,16]
[1,2,3,4,5,17]
[1,2,3,4,5,18]
...............
现在希望将这样的数据入库.现在有数据库表hmk,结构为
hmkid,int(11),no,pri,,auto_increment
l1,int(10) unsigned,no,,,
l2,int(10) unsigned,no,,,
l3,int(10) unsigned,no,,,
l4,int(10) unsigned,no,,,
l5,int(10) unsigned,no,,,
l6,int(10) unsigned,no,,,
请问如何在程序运行过程中编写php程序直接将数据写入数据库而不存入txt文档啊?
我的想法
php code$db=new mysqli(localhost,admin,admin,ssq);$db->query(truncate table hmk);$info = array(1, 2, 3,4,5,6);//$info是中间生成的的组合数组.foreach ($info as $skey=>$value){ //echo 'my array is underline:'.$key.=>.$value. ; $query=insert into hmk(l1,l2,l3,l4,l5,l6) values($values); $result=$db->query($query) ;} if (result)echo good luck ;else echo sorry ;$db->close();
问题2:要导入txt文档到数据库的程序有又要怎么写啊?我希望l1存储第一个数据l2存储第二个数据依次类推,
多谢帮忙.生成1-33的组合数据程序可以参考
php code$a = range(1, 33);$ar = combination($a, 6);//求组合高效率的10移动法function combination($numarr,$combinelen) { $numct = count($numarr); if($combinelen > $numct) return; $bin = str_pad('',$combinelen,'1'); $bin = str_pad($bin,$numct,'0',str_pad_right); $find = $bin; $rs[] = implode(' ',array_slice($numarr,0,$combinelen)); $j = 1; while(strrev($find) != $bin) { $k = explode('10',$find,2); $find = $find{0} === '0' ? strrev($k[0]).'01'.$k[1] : $k[0].'01'.$k[1]; for($i=0;$i
------解决方案--------------------
php code$fp = fopen('数据.txt', 'r');while( !feof($fp) ){ $line = trim( fget($fp) ); $sqlvalue .= '('. substr($line, 1, -1) . '),';}$sql = insert into hmk(l1,l2,l3,l4,l5,l6) values ;$sql = $sql . substr($sqlvalue, -1, 1); // 去掉末尾的 ,$db = new mysqli(localhost,admin,admin,ssq);$result = $db->query($sql);if( ! $result ){ echo $db->error(); var_dump($sql);}
------解决方案--------------------
每次查询只插入一条记录效率太低了,可以批量插入,比如每次50000条:

php code$data = array(array(1,2,3,4,5,6), array(1,2,3,4,57)); //先生成这样的data数组,每个元素是一组号码的数组$idx = 0;while($idx query($sql); $idx += 50000;}$db->close();
------解决方案--------------------

其它类似信息

推荐信息