php+ajax导入大数据时产生的问题处理

 更新时间:2014年06月11日 09:53:59   作者:  
介绍:就是想实现简单的ajax上传数据,但是当数据量较大的时候,问题就一个一个接着来了,其实数据也不是很大,就是csv格式数据 不到5w条数据。大小5M,一开始认为这个很简单,就是先上传一下文件,然后读取一下,存到数据库就好了,结果,可能我比较菜,弄了半天做出这个功能。环境是linux.

遇到的问题就从先到后的一一说吧。

问题1 按照我最初的想法,先上传文件再读取文件。这里问题就来了,当文件较大的时候上传较慢,导致客户看到的操作一直处于等待状态,不人性化。

处理办法:我是这样做的,大神有更好的办法,求介绍。我先把文件上传上去,然后把文件存到一个特定的文件夹就叫 import吧   ,然后返回一个这个文件名字。这样就确保了文件是上传成功的。并且我可以在他返回名字的这一步用js  给客户一个提示。然后就是ajax去请求php读取文件,插入数据库。可是问题来了。

问题2 当我用ajax去请求php读取文件并插入数据库的时候,遇到一个问题,就是ajax请求总是在1min的时候,断掉。我一想 ,这应该是php的最大执行时间max_execution_time的原因吧,结果我修改为300秒。还是这样,那我就认为会不会是apache的 最大get时间max_input_time呢,我就在代码加一个 ini_set  结果,用ini_get   查看max_input_time,用ini_set设置无效,还是60秒,在网上查了很多资料,还是不知道为啥。有大神知道的,请给我回复下。菜鸟先谢过了。那没办法,我只能去服务器把php.ini配置修改了。经理说不让修改的,为了测试,偷偷改了--最后修改回来了。修改之后,测试,还是不行。还是到一分钟 就执行超时。真的很纳闷。不知道什么原因。求指教。那没办法。

这种办法行不通了,对一个5m的文件只能分行读取了。然后就是对代码的一通修改,分行读取是这样操作的,先ajax请求,然后每次读取2000条  然后对这2000条数据进行处理,插入数据库(文章最后介绍一个好用的分行读取函数)。然后每次ajax执行完,返回一个状态符,和本次读取到的行数,然后下次接着读。知道最后读取完。这中间还遇到一个问题:就是当我对每一行数据进行查重的时候遇到的,是这样的,我对得到的内容进行循环,然后查一下每行是否存在,当我判断$count是否大于0 的时候,当已存在的时候,我用continue,执行下一次循环。但是当我在导入10000条的时候,总是在8000条的时候报错说 服务器内部错误。很闷,不解问什么,结果只能用if  else代替了。纳闷。一个小提醒:插入数据库的时候 不要一条一条的插入,最好这样 inset  into  aaa(`xx`,`xxx`)values('111','111'),('222','222')。这样 速度会快很多。

行号读取函数,SplFileObject这个类库真的很好用推荐。有知道我的问题的,求大神指教。

复制代码 代码如下:

function getFileLines($filename, $startLine, $endLine, $method = 'rb'){
      $content = array();
      $filename = DATA_PATH.DS.'import' . DS . $filename;
      $count = $endLine - $startLine;
      $fp = new SplFileObject($filename, $method);
      $fp->seek($startLine); // 转到第N行, seek方法参数从0开始计数
      for ($ii = 0; $ii <= $count; ++$ii) {
            $content[] = $fp->current(); // current()获取当前行内容
            $fp->next(); // 下一行
      }
      return array_filter($content); // array_filter过滤:false,null,''
}

相关文章

  • PHP SPL标准库之数据结构堆(SplHeap)简单使用实例

    PHP SPL标准库之数据结构堆(SplHeap)简单使用实例

    这篇文章主要介绍了PHP SPL标准库之数据结构堆(SplHeap)简单使用实例,本文还同时讲解了最大堆(SplMaxHeap)、最小堆(SplMinHeap)的相关知识,需要的朋友可以参考下
    2015-05-05
  • thinkPHP中验证码的简单使用方法

    thinkPHP中验证码的简单使用方法

    这篇文章主要介绍了thinkPHP中验证码的简单使用方法,涉及thinkPHP验证码逻辑功能的实现与界面显示的相关技巧,需要的朋友可以参考下
    2015-12-12
  • YII分模块加载路由的实现方法

    YII分模块加载路由的实现方法

    这篇文章主要介绍了YII分模块加载路由的实现方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • PHP链接MySQL的常用扩展函数

    PHP链接MySQL的常用扩展函数

    这篇文章主要介绍了PHP链接MySQL的常用扩展函数,需要的朋友可以参考下
    2014-10-10
  • 使用PHPStudy在本地快速建立网站并实现局域网外访问(无公网IP)

    使用PHPStudy在本地快速建立网站并实现局域网外访问(无公网IP)

    这篇文章主要为大家介绍快速在本地环境下搭建web网站,同时实现可在外网环境下访问的方法,文中有详细的图文介绍,具有一定的参考价值,需要的朋友可以参考下
    2023-10-10
  • Laravel模型事件的实现原理详解

    Laravel模型事件的实现原理详解

    模型事件在 Laravel 的世界中,你对 Eloquent 大多数操作都会或多或少的触发一些模型事件,下面这篇文章主要给大家介绍了关于Laravel模型事件的实现原理,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴。
    2018-03-03
  • php 分页函数multi() discuz

    php 分页函数multi() discuz

    discuz摘出来的php分页函数multi(),大家以后也可以从discuz来获取各种比较好的函数了,学习要注意借鉴。
    2009-06-06
  • laravel框架中间件 except 和 only 的用法示例

    laravel框架中间件 except 和 only 的用法示例

    这篇文章主要介绍了laravel框架中间件 except 和 only 的用法,简单说明了中间件 except 和 only的功能,并结合实例形式分析了laravel框架中间件 except 和 only 相关使用技巧,需要的朋友可以参考下
    2019-07-07
  • Yii调试查看执行SQL语句的方法

    Yii调试查看执行SQL语句的方法

    这篇文章主要介绍了Yii调试查看执行SQL语句的方法,涉及Yii配置文件的相关设置方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • laravel自定义分页效果

    laravel自定义分页效果

    这篇文章主要为大家详细介绍了laravel自定义分页实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07

最新评论