PHP对接口执行效率慢的优化

摘要:
PHP对慢界面执行效率的优化PHP对慢接口执行效率的最优化从多个方面造成了低执行效率。从代码层面来看,低代码质量也会对执行效率产生很大影响。在数据量方面,查询数据量太大,SQL语句太复杂,执行速度慢。数据查询的优化涉及SQL或数据库的优化。下面是一些简单的优化方案。SQL优化。查询表数据时,请查询准确的字段名称,以避免不必要的字段查询。对于SQL优化,请适当使用查询和模糊查询。
PHP对接口执行效率慢的优化

PHP对接口执行效率慢的优化

造成执行效率低的原因可以由很多方面找原因
  • 从代码层面,代码质量低,执行效率也会有很大影响的。
  • 从硬件方面,服务器配置低,服务器配置是基础,这个跑不动肯定慢。
  • 从数据量方面,查询数据量过多,sql语句过于繁杂,执行缓慢。
服务器

从配置上做提升,对于系统整体的执行效率是相当明显的,这一点没有什么好质疑的,只要有实力,自然就可以多在这方面做提升了。

数据查询

这个查询的优化,涉及sql的优化,或者到数据库的优化,下面有几个简单的优化方案。

  • sql的优化,适当使用链表查询,使用连接(JOIN)来代替子查询,一般大表和多表的情况避免使用JOIN,这种情况下使用JOIN反而达不到简化查询的效果。
  • sql的优化,查询表数据时精确字段名进行查询,避免不必要的字段查询。
  • sql的优化,适当使用主外键和索引,索引字段的查询效率在大表查询的效率对比相当明细。
  • sql的优化,适当使用in查询,适当使用模糊查询。

    ··········
  • 数据库的优化,字段使用合理的字段类型,另外一个提高效率的方法是在可能的情况下,应该尽量把字段设置为NOTNULL,避免空间浪费。
  • 数据库的优化,合理设计表结构。
  • 数据库的优化,合理设计索引,在联表查询或条件筛选中,数据表增加索引后查询的效率会快特别多。

    ··········
代码优化

代码上的优化也是因人而异的,每个人可能编码习惯和风格不同,对于提高代码性能有各自的见解,以下是我的部分看法。

  • foreach合理使用,尽量少在循环中套用循环,在循环次数过多的情况下,非常耗性能。
  • 循环中,尽量避免数据操作,特别是查询操作,在循环次数过多的情况下,多次调用效率很低,可一次获取数据再拼接。
  • 同理,在循环中,避免配置的多次获取,和time()函数方法的调用,这种一次声明就可以重复使用。
  • 在php中,单引号和双引号是有区别的,作为一种习惯字符串我都用单引号,因为它无需编译,对于效率,可能谈不上差异大小,可能就一点点
  • 合理利用在php中的函数,像数组函数就非常丰富,要充分利用,一般不要自己去做他本身就支持的函数方法
  • 可以用上字典的概念,将数组以新索引形式存储起来,我在数据的重组中很常用
  • 根据场景,合理使用缓存可以减少重复的数据查询,提高效率
  • 合理拆分功能,比如一个列表查询,并带有详情查看,可以将此处拆成两个接口实现,在需要时获取数据,减少资源浪费。
    ··········
 
  • 相关阅读:
    Linux之硬件资源管理
    Linux之vi 文本编辑命令
    [2]窗口程序的创建
    [1]cs辅助项目分解
    1.3 Windows操作系统
    (PYG)学习去除软件自效验
    CSUST 4006-你真的会树套树套树吗?(贪心|dp)
    CSUST 4003-你真的会泡面吗?(优先队列模拟)
    2020牛客暑期多校第八场I-Interesting Computer Game(离散化+并查集)
    2020牛客暑期多校K-Kabaleo Lite(贪心)
  • 原文地址:https://www.cnblogs.com/lvtiansong/p/9522450.html
  • 免责声明:文章转载自《PHP对接口执行效率慢的优化》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

    上篇java-mysql(3) 读写imageHDU-2647 Reward(链式前向星+拓扑排序)下篇

    宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

    相关文章

    关于php性能优化

    php性能优化 1.尽量静态化: 如果一个方法能被静态,那就声明它为静态的,速度可提高1/4,甚至我测试的时候,这个提高了近三倍。 当然了,这个测试方法需要在十万级以上次执行,效果才明显。 其实静态方法和非静态方法的效率主要区别在内存:静态方法在程序开始时生成内存,实例方法在程序运行中生成内存,所以静态方法可以直接调用,实例方法要先成生实例,通过实例调用...

    python之版本管理

    linux 环境下怎样对不同的python环境进行 方便的切换呢?update-alternatives工具能够非常方便的帮我们完成这个任务。而windows环境下可通过anaconda来完成. 1.通过update-alternatives工具来管理python版本的切换 2.update-alternatives的使用: 3.创建python的不同版本...

    MongoDB Python官方驱动 PyMongo 的简单封装

    最近,需要使用 Python 对 MongodB 做一些简单的操作,不想使用各种繁重的框架。出于可重用性的考虑,想对 MongoDB Python 官方驱动 PyMongo 做下简单封装,百度一如既往的未能给我一个满意的结果,于是有了下文。 【正文】 PyMongo,MongoDB Python官方驱动 docs: https://api.mongo...

    php 在docker 中使用composer 报内存溢出的解决方法

    最近 需要用到有盟的推送,不想自己写,准备在github上面找个来改改,本地用的环境是docker 镜像,然后在docker 中 composer 时的时候,报了一个错 docker exec -it www /bin/bash root@85c8ee9b5e27:/var/www/html/newyouchengdu# composer require...

    深入理解PHP内核(十四)类的成员变量及方法

    原文链接:http://www.orlion.ga/1237/ 类的成员变量在PHP中本质是一个变量,只是这些变量都归属于某个类,并且给这些变量是有访问控制的。 类的成员方法在PHP中本质是一个函数,只是这个函数以类的方法存在,他可能是一个类方法也可能是一个实例方法,并且在这些方法都加上了类的访问控制。类的成员方法是现实世界实体行为的抽象,可以用来实现类的...

    安装swoole扩展

    一、wget -c http://pecl.php.net/get/swoole-4.3.4.tgz 二、解压swoole包            tar xzvf swoole-4.3.4.tgz 三、生成configure配置文件   cd swoole-4.3.4   phpize      //生成./configure文件   ./configu...