Php 从SQL Server检索数据并将其转换为json格式?

Php 从SQL Server检索数据并将其转换为json格式?,php,sql-server,json,angularjs,windows,Php,Sql Server,Json,Angularjs,Windows,我正在使用PHP5.6.0并连接到本地SQL Server。我能够检索数据,但它是数组格式的。我想把它转换成json格式 我得到的: ( [date] => 2013-02-05 16:02:02.000000 [timezone_type] => 3 [timezone] => America/New_York ) ( "date" : "2013-02-05 16:02:02.000000", "timezone_type

我正在使用PHP5.6.0并连接到本地SQL Server。我能够检索数据,但它是数组格式的。我想把它转换成json格式

我得到的:

(     
    [date] => 2013-02-05 16:02:02.000000
    [timezone_type] => 3
    [timezone] => America/New_York
)
(
    "date" : "2013-02-05 16:02:02.000000",
    "timezone_type" : "3",
    "timezone" : "America/New_York"
)
$sql = "SELECT * FROM table";
$stmt = sqlsrv_query($conn, $sql);

$result = array(); 

do {
    while ($row = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)){
    $result[] = print_r($row); 
    }
} while (sqlsrv_next_result($stmt));


echo json_encode($result);


sqlsrv_free_stmt($stmt);
sqlsrv_close($conn);
我想要什么:

(     
    [date] => 2013-02-05 16:02:02.000000
    [timezone_type] => 3
    [timezone] => America/New_York
)
(
    "date" : "2013-02-05 16:02:02.000000",
    "timezone_type" : "3",
    "timezone" : "America/New_York"
)
$sql = "SELECT * FROM table";
$stmt = sqlsrv_query($conn, $sql);

$result = array(); 

do {
    while ($row = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)){
    $result[] = print_r($row); 
    }
} while (sqlsrv_next_result($stmt));


echo json_encode($result);


sqlsrv_free_stmt($stmt);
sqlsrv_close($conn);
这是我的代码:

(     
    [date] => 2013-02-05 16:02:02.000000
    [timezone_type] => 3
    [timezone] => America/New_York
)
(
    "date" : "2013-02-05 16:02:02.000000",
    "timezone_type" : "3",
    "timezone" : "America/New_York"
)
$sql = "SELECT * FROM table";
$stmt = sqlsrv_query($conn, $sql);

$result = array(); 

do {
    while ($row = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)){
    $result[] = print_r($row); 
    }
} while (sqlsrv_next_result($stmt));


echo json_encode($result);


sqlsrv_free_stmt($stmt);
sqlsrv_close($conn);
我的理解是json_encode应该转换我的数据,但它似乎不是这样工作的


谢谢大家!

你的逻辑很不合理,试着这样做:

$sql = "SELECT * FROM table";
$stmt = sqlsrv_query($conn, $sql);

$result = array(); 

while ($row = mssql_fetch_array($stmt))
{
 array_push($result, $row);
} 

echo json_enconde($result);


sqlsrv_free_stmt($stmt);
sqlsrv_close($conn);

我猜你的代码中有两个错误。第一个是

$result[] = print_r($row); 
您正在执行一个函数,同时在数组中推送值。您应该在这里推送数组中的值。像

$result[] = $row;
第二个是,编码后不打印JSON变量。所以你的代码是

$sql = "SELECT * FROM table";
$stmt = sqlsrv_query($conn, $sql);

$result = array(); 

do {
    while ($row = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)){
       $result[] = $row; 
    }
} while (sqlsrv_next_result($stmt));


sqlsrv_free_stmt($stmt);
sqlsrv_close($conn); //Close the connnectiokn first

echo json_encode($result); //You will get the encoded array variable

Sql Server 2016具有FOR JSON子句,可自动将结果集转换为JSON请参见

为什么使用
print\r($row)
?这只是一个带有调试的打字错误吗?如果没有打印,请尝试_r@Styphon我使用print\r是因为这是我能够真正看到代码的唯一方式。如果没有它,我会得到一个空白屏幕。然后你应该使用
print\r($row)$结果[]=$行。您当前拥有的内容无效。感谢您提供此代码,但我正在使用SQL Server,因此无法使用mssql_fetch_array()是的,您可以!mssql_fetch_数组不是mysql_fetch_数组,如图所示。感谢您提交@Vinet,但由于某些原因,这仍然没有帮助。我得到一个空白屏幕。在脚本末尾调用
die()
exit()