PHP- SQLSRV_FETCH_ASSOC & sqlsrv_fetch_array 错误
PHP- Error with SQLSRV_FETCH_ASSOC & sqlsrv_fetch_array
我使用此代码从 excel 中的 sql 服务器查询下载结果。
连接和查询工作正常,我已经正确安装了 sqlsrv 扩展。
但我仍然收到这样的错误
"Use of undefined constant SQLSRV_FETCH_ASSOC - assumed
SQLSRV_FETCH_ASSOC'"
"Warning: sqlsrv_fetch_array() expects parameter 2 to be long"
我认为问题出在 SQLSRV_FETCH_ASSOC
。
任何帮助将不胜感激。
function cleanData(&$str)
{
$str = preg_replace("/\t/", "\t", $str);
$str = preg_replace("/\r?\n/", "\n", $str);
if(strstr($str, '"')) $str = '"' . str_replace('"', '""', $str) . '"';
}
$serverName = "********";
$connectionInfo = array( "Database"=>"****", "UID"=>"***", "PWD"=>"*****");
$connect = sqlsrv_connect( $serverName, $connectionInfo);
// filename for download
$filename = "website_data_" . date('Ymd') . ".xls";
header("Content-Disposition: attachment; filename=\"$filename\"");
header("Content-Type: application/vnd.ms-excel");
$flag = false;
$query="select * from business_partners ORDER BY 1 desc";
$result = sqlsrv_query($connect, $query) or die('A error occured: ' . sqlsrv_errors());
while(false !== ($row = sqlsrv_fetch_array($result,SQLSRV_FETCH_ASSOC)))
{
if(!$flag) {
// display field/column names as first row
echo implode("\t", array_keys($row)) . "\r\n";
$flag = true;
}**strong text**
array_walk($row, 'cleanData');
echo implode("\t", array_values($row)) . "\r\n";
}
exit;
我无法解释为什么在明确加载扩展时不定义常量,但您应该能够通过自己定义常量来避免该问题。
SQLSRV_FETCH_ASSOC
has the value 2,所以你应该把这个添加到某个地方,最好是在你总是包含的文件中:
if ( !defined( 'SQLSRV_FETCH_ASSOC' ) )
define( 'SQLSRV_FETCH_ASSOC', 2 );
if ( !defined() )
子句可确保您的代码在实际问题得到解决并且常量突然重新出现时不会中断。
或者,如果您只在文件中使用它一次并且定义常量真的不值得(除了可读性),您可以只使用实际值作为参数:
$row = sqlsrv_fetch_array( $result, 2 ); // 2 = SQLSRV_FETCH_ASSOC
我使用此代码从 excel 中的 sql 服务器查询下载结果。 连接和查询工作正常,我已经正确安装了 sqlsrv 扩展。 但我仍然收到这样的错误
"Use of undefined constant SQLSRV_FETCH_ASSOC - assumed SQLSRV_FETCH_ASSOC'"
"Warning: sqlsrv_fetch_array() expects parameter 2 to be long"
我认为问题出在 SQLSRV_FETCH_ASSOC
。
任何帮助将不胜感激。
function cleanData(&$str)
{
$str = preg_replace("/\t/", "\t", $str);
$str = preg_replace("/\r?\n/", "\n", $str);
if(strstr($str, '"')) $str = '"' . str_replace('"', '""', $str) . '"';
}
$serverName = "********";
$connectionInfo = array( "Database"=>"****", "UID"=>"***", "PWD"=>"*****");
$connect = sqlsrv_connect( $serverName, $connectionInfo);
// filename for download
$filename = "website_data_" . date('Ymd') . ".xls";
header("Content-Disposition: attachment; filename=\"$filename\"");
header("Content-Type: application/vnd.ms-excel");
$flag = false;
$query="select * from business_partners ORDER BY 1 desc";
$result = sqlsrv_query($connect, $query) or die('A error occured: ' . sqlsrv_errors());
while(false !== ($row = sqlsrv_fetch_array($result,SQLSRV_FETCH_ASSOC)))
{
if(!$flag) {
// display field/column names as first row
echo implode("\t", array_keys($row)) . "\r\n";
$flag = true;
}**strong text**
array_walk($row, 'cleanData');
echo implode("\t", array_values($row)) . "\r\n";
}
exit;
我无法解释为什么在明确加载扩展时不定义常量,但您应该能够通过自己定义常量来避免该问题。
SQLSRV_FETCH_ASSOC
has the value 2,所以你应该把这个添加到某个地方,最好是在你总是包含的文件中:
if ( !defined( 'SQLSRV_FETCH_ASSOC' ) )
define( 'SQLSRV_FETCH_ASSOC', 2 );
if ( !defined() )
子句可确保您的代码在实际问题得到解决并且常量突然重新出现时不会中断。
或者,如果您只在文件中使用它一次并且定义常量真的不值得(除了可读性),您可以只使用实际值作为参数:
$row = sqlsrv_fetch_array( $result, 2 ); // 2 = SQLSRV_FETCH_ASSOC