新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
肯定会很慢,for循环一次那就读取数据库一次,循环上万次你说数据库能受得了不?最好一次去除数据,然后再对去除的数据操作
创新互联公司主营柳城网站建设的网络公司,主营网站建设方案,app软件定制开发,柳城h5微信小程序定制开发搭建,柳城网站营销推广欢迎柳城等地区企业咨询
双层循环啊, 数量是 $gift * $fi的个数。 百万级别的。
简单的就是将excel中的数据导入的数据库中(可以是另外一个表),将验证码字段建索引。然后再排查重复的,纯sql就很快了。
foreach 只是php中最常用的函数,其本身是并不会耗费太多的系统运行内存的。
造成你读取数据太慢的原因一般是出现在服务器上,或者说你的电脑配置低运行这些代码需要多花一点时间;
也有可能是你的数据库数据太多了,一次性读取出来会很卡,这个时候你就需要分页显示这些数据了。
那就用sphinx 技术,目前这个是最好的,没有之一。
下面是我百度百科弄过来的,怎么使用还得你自己看白皮书了。
Sphinx的主要特性包括:
高速索引 (在新款CPU上,近10 MB/秒);
高速搜索 (2-4G的文本量中平均查询速度不到0.1秒);
高可用性 (单CPU上最大可支持100 GB的文本,100M文档);
提供良好的相关性排名
支持分布式搜索;
提供文档摘要生成;
提供从MySQL内部的插件式存储引擎上搜索
支持布尔,短语, 和近义词查询;
支持每个文档多个全文检索域(默认最大32个);
支持每个文档多属性;
支持断词;
支持单字节编码与UTF-8编码。[1]
数据库的读取能一次查询完成的尽量不要分成多次查询
不知道你用的是什么框架,如果有where_in方法的话可以用它来解决,先要构造出order_sn值的数组
没有的话就自己构造'or'条件字符串,然后用where一次查询完成
给你个思路
先最大化 PHP 效率充分利用 系统资源。
把 sql 拆开比如2万一个用一个 php 去跑 总共用5个 php 一起跑。
然后最大化 mysql 效率
查一下mysql 的瓶颈在哪。针对性的去优化。
查询慢 就看看索引什么的
写慢就查查 buffer 什么的。
这里强烈建议读写分离。
用不通的数据库实例去分别处理读写。
再看看磁盘 IO 性能。看看队列数据。不行就上阵列。或者单表部署单个磁盘。或者读写在不同的磁盘进行。
当然用缓存也可以。
比如把10万条都独出来存到 memcache 等内存缓存中。循环处理数据的时候读内存的数据不用查数据库。
还有终极大招。
你直接把数据库都搬内存里面。。。