慢PHP功能,将大量数据放入数组

时间:2015-03-24 14:30:51

标签: php sql

我有一个从SQL Server数据库获取数据的函数。结果集大约为5900条记录,每条记录中有两列(CodeName) 但是,在某些情况下,此功能可能需要一段时间才能运行2-5甚至更长。

以下是代码:

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;
}

运行此更好的方法是什么?这是输出数组的转储:

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)

1 个答案:

答案 0 :(得分:0)

我认为问题在于您的数据库包装器。另外,您每次在函数上建立新的数据库连接吗?

  

$ Connection = Database :: odbc(" sage");

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

要考虑的另一件事是实现一个缓存系统来处理大量数据,这样你就不必多次查询数据库。如果你不熟悉缓存,那么一个简单的缓存类就是" phpfastcache"。