求关于php excel导入大数据到mysql的解决办法

如题,字段有40个,需要导入的EXCEL数据不到5万条。有没有好的解决方法使用php将excel导入到mysql数据库。求php代码的实现步骤。... 如题,字段有40个,需要导入的EXCEL数据不到5万条。
有没有好的解决方法使用php 将excel导入到mysql数据库。
求php代码的实现步骤。
展开
 我来答
匿名用户
推荐于2016-06-22
展开全部

下载 PHPExcel
    

require_once( './PHPExcel/IOFactory.php');
$filePath = 'D:/xxx.xlsx'; //excel 文件名 
$objReader = new PHPExcel_Reader_Excel2007();  //具体查看(Documentation/Examples/Reader/exampleReader01.php)
$objPHPExcel = $objReader->load($filePath);
$sheetData = $objPHPExcel->getActiveSheet()->toArray(null,true,true,true);
$insql = 'insert into 表名(x,x,x) valeus';
//遍历数组 $sheetData
//如果有标题 先删除 unset($sheetData[1]);
foreach($sheetData as $k => $data){
    $insql .= '('.$data['A'].','.$data['B'].','.$data['C'].'),';
    //一次插入100条数据  减少数据库压力
    if(($k+1 / 100) == 0){
        $insql = rtrim($insql,',').';'; //将最后的逗号替换成分好
        //插入数据库 并且重置 字符串 $insql  
        //或者保存到文件中 利用source 命令插入数据库
    }
}
wfighter
2014-05-07
知道答主
回答量:36
采纳率:0%
帮助的人:19万
展开全部
  1. 使用PHPExcel类读取excel文件到数组中

  2. 遍历数组写入mysql

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
snje1987
2014-04-12 · TA获得超过160个赞
知道小有建树答主
回答量:89
采纳率:0%
帮助的人:109万
展开全部
可以使用PHPExcel,PHPExcel是一个php制作的工具,能够读取和生成excel文件,功能非常丰富,除了基本的读取和生成之外,还可以设定单元格、文字等的格式、插入图片。
它的功能很多,具体的用法可以查看它的帮助文档,里面解释很详细,但是都是英文的。
网址:http://phpexcel.codeplex.com/
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友43b55ca
2019-06-14
知道答主
回答量:14
采纳率:0%
帮助的人:9786
展开全部
问题原因: 模型数据过大:虽然Excel文件本身不大可能不到1M,但是对于超过10个的sheet页,以及每个页有大量的列表,生成的JSON模型可能达到几个M,以大连行政平台的费用分摊为例,JSON模型达6M;
解决方法,需要设置几个关口: (1)使用tomcat服务器,tomcat对于前台发送而来的ajax post请求有最大值限制,一般默认为2M,所以需要maxPostSize=“0”
(2)如果使用mysql数据库,mysql数据库自身对于客户端传递而来的package包也有限制,需要登录mysql后台,设置max_allowed_packet,默认是1M set global max_allowed_packet = 210241024*10; // 设置为20M
(3)对于mysql数据库中的form_templete表中的content字段必须是mediumtext 或者longtext,否则也会出现无法插入的问题
具体可参考东软平台产品官网,https://platform.neusoft.com/
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式