Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/entity-framework/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
缓慢的php函数,将大量数据放入数组_Php_Sql - Fatal编程技术网

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

缓慢的php函数,将大量数据放入数组,php,sql,Php,Sql,我有一个从SQL Server数据库获取数据的函数。结果集大约有5900条记录,每条记录中有两列代码和名称。 但是,在某些情况下,此函数可能需要相当长的时间才能运行2-5次,甚至更长时间 代码如下: public function GetAllProductCodes() { $Connection = Database::odbc("sage"); $sql = "SELECT Code, Name FROM STKStockItemView"; $ResultSet

我有一个从SQL Server数据库获取数据的函数。结果集大约有5900条记录,每条记录中有两列代码和名称。 但是,在某些情况下,此函数可能需要相当长的时间才能运行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)

我相信问题在于你的数据库包装器。另外,您是否每次都在函数上建立新的数据库连接

$Connection=数据库::odbcsage

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

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