$arr= array();
$query = $db->query("SQL语句");
while($row = $db->fetch_array($query)) {
$arrtmp['content']= $row['content ];

$arr[] = $arrtmp;
}使用的是数组来存放查询出来的数据,有标题有摘要等等现在遇到的问题是这样的,mysql数据库连接本地,测试速度很快,但是mysql数据库远程连接就很慢了,skip-name-resolve加了没有用,可以排除。
这个问题几天了没有解决,很是纳闷,请教大侠!

解决方案 »

  1.   

    另外附加一句,mysql远程连接的那台服务器到程序所在的服务器之间的网速是很快的。
      

  2.   

    mysql数据库连接本地,测试速度很快,但是mysql数据库远程连接就很慢了大型点的 解决方法 RAD数据库其他的解决方法 
    1.将数据库设置在本地 定时同步数据库数据
    2.缓存数据
    3.将本地的服务器托管到数据库相同的机房
      

  3.   

    问题的症结点是保存$arrtmp['content']= $row['content ];
    这个的问题,有些大数据我注释,速度还是很快,但是这些数据又是需要的
    想请教数组保存大数据有什么优化的东西,为什么mysql连接远程很慢,换成本地却非常快?
      

  4.   

    mysql_query 取得的结果集是缓存在 mysql 那边的
    mysql_fetch_array 每次读取的是那个缓存在 mysql 的记录于是你每读一次就有一次远程数据传输,自然就很慢了mysqli 有一个函数可以一次性的将查询结果集取回,并缓存在本地
    不过函数名不记得了(因为不用mysqli),前两个月在这里讨论过pdo 提供了 fetchall 方法,可以一次性的将结果集转换成数组
    好像 mysqli 也提供了只要你的数据库类不是基于 mysql函数 的,总是有办法解决远程读取慢的问题的
      

  5.   

    恩,是的,代码还有
    function gettag($id,$flag){
    $fTag="";
    global $db,$tablepre;
    $query= $db->query("SELECT tagname FROM tags WHERE tid='$id' LIMIT 1");
    if($row = $db->fetch_array($query)){
    $fTag = $row['tagname'];
    }
    if($flag==0){
    return $fTag;
    }else{
    return urlencode($fTag);
    }
    }这个代码注释大概可以快1秒,本地可以忽略。
    另外下面还有几个赋值给数组的字段,每个差不多也是1秒,加起来就要个5-6秒再打开,这个速度就很慢了
      

  6.   

    你好,使用的是mysql_fetch_array另外fetchall 我再试下 
      

  7.   

    现在别用原始的php mysql函数了
    换mysqli或者pdo吧
    尤其是pdo比较好用
      

  8.   

    恩,现在主要是这几天一直没有找到真正的原因,为什么远程就很慢
    数据页面包括样式和图片只有200多k,而且程序服务器到数据库服务器之间的网络通信良好,ping的时间在51ms左右。
    为什么本地我设置显示50条的数据都是一刷就出来了,而远程连接之后显示10条都需要3秒以上,数据库和程序感觉该优化的都优化过了
      

  9.   

    假定读取一条记录的时间是 50ms
    那么 50 条记录就是 50 * 50 = 2500 ms = 2.5sping 的结果是单边平均耗时
    而通讯是双边的