zoukankan      html  css  js  c++  java
  • php 代码优化提高MySQl的运行效率

    [mysqld] 
    log="d:/temp/mysql.log" 
    log_slow_queries="d:/temp/mysql_slow.log" 
    long_query_time=1


    这个目录是要已经存在的。重启mysql服务,就可以记录了。

    查看sql记录后大吃一惊,查询的数量惊人,随便一个页面,sql查询都在几十条,多的有上千条!

    以论坛来说吧,一个页面的数据库查询次数也就是10次一下,用了缓存的还可以再低。这样算的话,就相当于原来几十倍的负担,能不挂?

    谁人也不能那边有毅力写下上百条的查询啊,所以肯定是循环查询。sql语句也表明这一点。知道原因了就好改了,找到相关页面,改掉循环查询,例如,有一个页面,要显示所有地区分类和该分类下的文章数,先不考虑数据库的结构优化,就程序而言,原来的大概是这样子的 
    复制代码 代码如下:
    $sql1="SELECT aid,count(*) as cc FROM pz_content WHERE uid=$uid group by aid"; 
    $rs1=$db->query($sql1); 
    if(is_array($rs1)){ 
    foreach($rs1 as $r2881064151){ 
    输出... 
    echo id2name($r1->aid); 


    ............ 
    function id2name($aid) 

    $sql="select ename from pz_area_a where aid_a=".$id; 
    $result=mysql_query($sql); 
    $row=mysql_fetch_object($result); 
    return $row->ename; 
    }

    先不管代码的容错,看实现就知道,他先读取了该用户的相关文章并按地区ID进行了分组和统计个数,然后再每个地区每个地区地输出地区名字,所以,如果有1w个地区,这里就要查询1w次。放上一个计时的代码,看了下,大概耗用内存6M,执行时间16秒,累计查询1001次

    其实,这里是只要用一句sql就可以搞定的事情,并不需要循环。

    复制代码 代码如下:
    $sql1="select pz_area.aid,pz_area.ename,tb1.cc from pz_area right join (SELECT aid,count(*) as cc FROM pz_content WHERE uid=$uid group by aid) as tb1 on pz_area.aid=tb1.aid"; 
    $rs1=$db->query($sql1); 
    if(is_array($rs1)){ 
      foreach($rs1 as $r1){ 
    输出... 
       echo $r1->ename; 
      } 
    }

    问题就可以解决了。重新运行下,内存耗用差不多,查询1次,CPU执行时间只有647毫秒,和原来的差了26倍!再看一下,发现这个pz_content的表,记录还算比较多的,有经常要按地区查询划分之类的,但是原来什么索引也没有。顺道在aid上加上一个索引,执行时间缩短到432毫秒。

  • 相关阅读:
    结构化思考力
    对象序列化解析
    单元测试的规范
    关于CefSharp的坎坷之路
    构建基于Chromium的应用程序
    C# 面向切面编程(AOP)--监控日志记录方案
    CefSharp 中断点 已达到中断点
    用批处理命令实现激活office2016
    Winform开发中的困境及解决方案
    VUE+Element 前端应用开发框架功能介绍
  • 原文地址:https://www.cnblogs.com/cbryge/p/6169314.html
Copyright © 2011-2022 走看看