phpajax导入大数据时产生的问题处理

phpajax导入大数据时产生的问题处理

ID:28446835

大小:59.62 KB

页数:3页

时间:2018-12-10

phpajax导入大数据时产生的问题处理_第1页
phpajax导入大数据时产生的问题处理_第2页
phpajax导入大数据时产生的问题处理_第3页
资源描述:

《phpajax导入大数据时产生的问题处理》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、php+ajax导入大数据时产生的问题处遇到的问题就从先到后的一一说吧。问题1按照我最初的想法,先上传文件再读取文件。这里问题就来了,当文件较大的时候上传较慢,导致客户看到的操作一直处于等待状态,不人性化。处理办法:我是这样做的,大神有更好的办法,求介绍。我先把文件上传上去,然后把文件存到一个特定的文件夹就叫import吧,然后返回一个这个文件名字。这样就确保了文件是上传成功的。并且我可以在他返回名字的这一步用js给客户一个提示。然后就是ajax去请求php读取文件,插入数据库。可是问题来了。问题2当我用ajax去请求php读取文件并插入数

2、据库的时候,遇到一个问题,就是ajax请求总是在1min的时候,断掉。我一想,这应该是php的最大执行时间max_execution_time的原因吧,结果我修改为300秒。还是这样,那我就认为会不会是apache的最大get时间max_input_time呢,我就在代码加一个ini_set结果,用ini_get查看max_input_time,用ini_set设置无交女,还是60秒,在网上查了很多资料,还是不知道为啥。有大神知道的,请给我回复下。菜鸟先谢过了。那没办法,我只能去服务器把php.ini配置修改了。经理说不让修改的,为了测试,

3、偷偷改了--最后修改回来了。修改之后,测试,还是不行。还是到一分钟就执行超时。真的很纳闷。不知道什么原因。求指教。那没办法。这种办法行不通了,对一个5m的文件只能分行读取了。然后就是对代码的一通修改,分行读取是这样操作的,先ajax请求,然后每次读取XX条然后对这XX条数据进行处理,插入数据库(文章最后介绍一个好用的分行读取函数)。然后每次ajax执行完,返回一个状态符,和本次读取到的行数,然后下次接着读。知道最后读取完。这中间还遇到一个问题:就是当我对每一行数据进行查重的时候遇到的,是这样的,我对得到的内容进行循环,然后查一下每行是否存在

4、,当我判断$00皿1是否大于0的时候,当已存在的时候,我用continue,执行下一次循环。但是当我在导入10000条的时候,总是在8000条的时候报错说服务器内部错误。很闷,不解问什么,结果只能用ifelse代替了。纳闷。一个小提醒:插入数据库的时候不要一条一条的插入,最好这样insetintoaaa('xx',xxx)values(’111’,’111’),C222’,’222’)。这样速度会快很多。行号读取函数,splfileobject这个类库真的很好用推荐。有知道我的问题的,求大神指教。代码如下:functiongetfileli

5、nes($filename,$startline,$endline,$method=’rb’){$content=array();$filename=data_path.ds.’import’.ds.$filename;$count=$endline-$startline;$fp=newsplfileobject($filename,$method);$fp-gt;seek($startline);//转到第n行,seek方法参数从0开始计数for($ii=0;$iilt;=$count;++$ii){$content[]=$fp-gt;c

6、urrent()://currentO获耳又当前行内容$fp-gt;next();//下一行returnarray_filter($content)://array_fi1ter过滤:false,null,

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。