如何将 XML SQL 数据类型从我的存储过程返回到 PHP


How to return an XML SQL data type from my stored procedure to PHP

我一直在尝试执行一个存储过程并返回一个XML数据类型,以便通过PHP显示。

这是我所拥有的 - 一个简单的存储过程,getXML,如下所示:

CREATE PROCEDURE [dbo].[getXML] 
AS
select --some fields
from --some table
for XML auto, elements
GO

当我通过 SQL Server Management Studio 执行它并输出 XML 结果集时,此语句工作正常。

如何让该结果集显示在 php 页面上?

到目前为止,我能够在PHP中执行以下操作:

<?php
  $server = 'thisServer';
  // Connect to MSSQL
 $link = mssql_connect($server, 'user', 'pass');
  if (!$link) {
      die('Something went wrong while connecting to MSSQL');
  }

  // Create a new statement
  $stmt = mssql_init('dbo.getXML');

  // Execute the statement
  $result = mssql_execute($stmt);
  $count = mssql_num_rows($result);
  if($count == 0)
  {
    print "<p>No results</p>";
  }
  else
  {
    $row = mssql_fetch_assoc($result);
        foreach($row as $field => $value):
            $field
        endforeach;
    mssql_data_seek($result, 0);
    while($row = mssql_fetch_assoc($result))
    {
    foreach($row as $value):
        =$value
    endforeach;
    }
    mssql_free_statement($stmt);
?>

虽然我可以打印结果,但它看起来很糟糕......根本不像 XML 输出。

如何将存储过程中的 XML 输出获取到 php 中?

我已经尝试过:sqlsrv_get_field和SQLSRV_PHPTYPE_STREAM(SQLSRV_ENC_CHAR)),但我一定是错误地使用它们并且无法使其工作。

多谢!

DECLARE @XML XML
SET @XML = (
SELECT something 
FROM sometable
FOR XML PATH('items'), ROOT('root')
)
SELECT CONVERT(NVARCHAR(MAX), @XML)