• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 3年前 (2022-01-23) 18次浏览 已收录 0个评论

[新手请教]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]
[

。本文来源gao!%daima.com搞$代*!码网1

搞代gaodaima码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

<!---ecms Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->$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."</br>" ;     $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

<!---ecms Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->$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<$numCt;$i++) $rs[$j] .=  $find[$i] ?  $numArr[$i] . " " : '';    $j++;  }  return $rs;}

——解决方案——————–

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 < count($data) - 1)) {    $ar = array();    if ($idx + 50000 query($sql);    $idx += 50000;}$db->close();
------解决方案--------------------


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:[新手请问]PHP写入MySQL数据库的有关问题
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址