PHP SQLSRV - 全文查询在参数化时不起作用

PHP SQLSRV - Full-Text Query Not Working When Parameterized

当我 运行 通过 PHP sqlsrv 驱动程序进行以下查询时,没有发生错误,但也没有返回任何行...如果我去掉问号(应该是参数) 并插入关键字,然后 returns 行就好了...

SELECT DISTINCT
  MAX(i.ID) AS ID,
  i.ItemLookupCode,
  MAX(i.DepartmentID) AS DepartmentID,
  MAX(i.CategoryID) AS CategoryID,
  MAX(i.Quantity) AS Quantity,
  MAX(CAST(i.Notes AS varchar(max))) AS Notes,
  MAX(CONVERT(varchar(30), i.Price, 1)) AS Price,
  MAX(i.SaleType) AS SaleType,
  MAX(i.SaleStartDate) AS SaleStartDate,
  MAX(i.SaleEndDate) AS SaleEndDate,
  MAX(CONVERT(varchar(30), i.SalePrice, 1)) AS SalePrice,
  MAX(i.PictureName) AS PictureName,
  MAX(n.SpoofStock) AS SpoofStock,
  MAX(n.PAM_Brand) AS Brand

FROM Item AS i

LEFT JOIN nitroasl_pamtable AS n
  ON i.ID = n.ItemID

WHERE CONTAINS(
  (i.ItemLookupCode, i.Notes, i.Description, i.ExtendedDescription),
  '? AND ?')

OR CONTAINS(
  (n.PAM_Brand, n.ManufacturerPartNumber, n.PAM_Keywords),
  '? AND ?')

AND ( i.WebItem = 1 AND i.Price > 0 )

GROUP BY i.ItemLookupCode

ORDER BY i.ItemLookupCode ASC

我已经验证我的参数数组是正确的...下面是我的脚本:

require LIBRARY_PATH . "/connect-db.php";

$tsql = "SELECT DISTINCT
          MAX(i.ID) AS ID,
          i.ItemLookupCode,
          MAX(i.DepartmentID) AS DepartmentID,
          MAX(i.CategoryID) AS CategoryID,
          MAX(i.Quantity) AS Quantity,
          MAX(CAST(i.Notes AS varchar(max))) AS Notes,
          MAX(CONVERT(varchar(30), i.Price, 1)) AS Price,
          MAX(i.SaleType) AS SaleType,
          MAX(i.SaleStartDate) AS SaleStartDate,
          MAX(i.SaleEndDate) AS SaleEndDate,
          MAX(CONVERT(varchar(30), i.SalePrice, 1)) AS SalePrice,
          MAX(i.PictureName) AS PictureName,
          MAX(n.SpoofStock) AS SpoofStock,
          MAX(n.PAM_Brand) AS Brand

        FROM Item AS i

        LEFT JOIN nitroasl_pamtable AS n
          ON i.ID = n.ItemID

        WHERE CONTAINS(
          (i.ItemLookupCode, i.Notes, i.Description, i.ExtendedDescription),
          '? AND ?')

        OR CONTAINS(
          (n.PAM_Brand, n.ManufacturerPartNumber, n.PAM_Keywords),
          '? AND ?')

        AND ( i.WebItem = 1 AND i.Price > 0 )

        GROUP BY i.ItemLookupCode

        ORDER BY i.ItemLookupCode ASC";

// Allows us to determine the number of rows returned
$cursorType = array('Scrollable' => SQLSRV_CURSOR_KEYSET);

$stmt = sqlsrv_query( $conn, $tsql, $params, $cursorType );

if ( !$stmt )
{
  die( FormatErrors( sqlsrv_errors() ) );
}

if( sqlsrv_has_rows( $stmt ) )
{
  while( $row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_ASSOC))
  {
    $results[] = $row;
  }
}

sqlsrv_free_stmt( $stmt );

require LIBRARY_PATH . "/disconnect-db.php";

上述脚本的参数数组如下所示:

Array
(
  [0] => displayport
  [1] => hdmi
  [2] => displayport
  [3] => hdmi
)

请注意,我会根据解析的关键字数量动态创建填充 "?" AND "?" 的字符串。我验证了字符串是正确的,上面反映了它们会产生什么。

那么,这不是一个有效的参数化 sqlsrv 查询吗?

CONTAINS 子句的第二个参数是您应该参数化的内容。

这部分:

WHERE CONTAINS(
  (i.ItemLookupCode, i.Notes, i.Description, i.ExtendedDescription),
  '"?" AND "?"')

OR CONTAINS(
  (n.PAM_Brand, n.ManufacturerPartNumber, n.PAM_Keywords),
  '"?" AND "?"')

应该这样写:

WHERE CONTAINS(
  (i.ItemLookupCode, i.Notes, i.Description, i.ExtendedDescription),
  ?)

OR CONTAINS(
  (n.PAM_Brand, n.ManufacturerPartNumber, n.PAM_Keywords),
  ?)

并且,假设您的 $params 看起来像这样:

 $params = ['a', 'b', 'c', 'd']

它应该看起来像:

 $params = [
   '"a" AND "b"', 
   '"c" AND "d"'
 ]