300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > [新手请问]PHP写入MySQL数据库的有关问题

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

时间:2018-08-16 01:20:24

相关推荐

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

后端开发|php教程

quot,array,values,unsigned,query

后端开发-php教程

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

其中一人中奖源码,ubuntu中架设网站,爬虫小实用案例,php写point,seo和爬虫lzw

$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存储第二个数据依次类推,

delphi 发邮件 源码,vscode菜单栏显示,ubuntu 搭建oj,tomcat 视频点播,淘宝爬虫商品,php 获取服务器名,南海页面seo优化怎么做,ktv营销网站模板,免费flash网站模板lzw

多谢帮忙.生成1-33的组合数据程序可以参考

PHP code

h5企业网站源码,vscode md 表格,mqtt ubuntu,tomcat自动映射,微信sqlite文件读取,下载插件后验证码自动生成显示出来的但是不让输入怎么回事,网络前端框架设计与实现,爬虫难吗 c语言基础,php电子商务网站,seo市场分析,java购物网站论文,app官网网页源码,政府信息万能模板下载lzw

$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,,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} === ? strrev($k[0]).1.$k[1] : $k[0].1.$k[1]; for($i=0;$i<$numCt;$i++) $rs[$j] .= $find[$i] ? $numArr[$i] . " " : \; $j++; } return $rs;}

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

PHP code

$fp = fopen(数据.txt, );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();

------解决方案--------------------

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。