首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >缓慢的php函数,将大量数据放入数组中

缓慢的php函数,将大量数据放入数组中
EN

Stack Overflow用户
提问于 2015-03-24 22:30:51
回答 1查看 66关注 0票数 0

我有一个从SQL Server数据库获取数据的函数。结果集大约有5900条记录,每条记录中有两列(CodeName)。

然而,这个函数可能需要相当长的时间才能运行2-5次,在某些情况下甚至更长。

代码如下:

代码语言:javascript
复制
public function GetAllProductCodes()
{
    $Connection = Database::odbc("sage");
    $sql = "SELECT Code, Name FROM STKStockItemView";
    $ResultSet = Database::execute($Connection, $sql);
    $i = 1;
    $array = array();
    while ($row = odbc_fetch_array($ResultSet)) {
        foreach ($row AS $key => $value) {
            $array[$i][$key] = $row[$key];
        }
        $i++;
    }
    return $array;
}

运行这项操作的最佳方式是什么?下面是输出数组的转储:

代码语言:javascript
复制
array (size=5867)
1 => 
array (size=2)
  'Code' => string '0010' (length=4)
  'Name' => string 'Product name' (length=14)
2 => 
array (size=2)
  'Code' => string '0957' (length=4)
  'Name' => string 'Product name' (length=27)
3 => 
array (size=2)
  'Code' => string '0958' (length=4)
  'Name' => string 'Product name' (length=20)
4 => 
array (size=2)
  'Code' => string '1050' (length=4)
  'Name' => string 'Product name' (length=16)
EN

回答 1

Stack Overflow用户

发布于 2015-03-24 22:38:15

我认为问题出在你的数据库包装器上。另外,你是否每次都在你的函数上建立一个新的数据库连接?

$Connection =数据库::odbc(“sage”);

因为如果是这样,那就不是个好主意。您应该在另一个文件(比如config.php)中建立一次数据库连接。

另一件需要考虑的事情是实现一个缓存系统来处理大量数据,这样你就不必查询数据库了。如果您不熟悉缓存,可以使用一个简单的缓存类“phpfastcache cache”。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29235271

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档