为啥 ORDER BY 子句中的绑定参数不对结果进行排序?

Posted

技术标签:

【中文标题】为啥 ORDER BY 子句中的绑定参数不对结果进行排序?【英文标题】:Why doesn't binding parameter in ORDER BY clause order the results?为什么 ORDER BY 子句中的绑定参数不对结果进行排序? 【发布时间】:2010-05-25 19:06:06 【问题描述】:

我在 PDO 语句的 ORDER BY 子句中绑定参数时遇到问题。 “orderBy”似乎没有传递给查询,因为结果没有像他们想象的那样排序。当我在查询中使用price 之类的列名而不是参数时,结果将按该列排序。代码是:

class Products 
    const ORDER_BY_NAME='name';
    const ORDER_BY_PRICE_PER_UNIT='price_per_unit';
    const ORDER_BY_PRICE='price';
    const ORDER_BY_MINIMUM_QUANTITY='minimum_quantity';

    // function returns array of all products

    public function getAllProducts($orderBy)  
        $db=Registry::getVariable('db');
        $pdoStatement=$db->prepare("SELECT name, minimum_quantity, price_per_unit, price, id FROM products ORDER BY :orderBy;");
        $pdoStatement->bindParam(':orderBy', $orderBy, PDO::PARAM_STR);
        $pdoStatement->execute();
        return $pdoStatement->fetchAll(PDO::FETCH_ASSOC);
    

稍后我会打电话:

 $products=new Products();

 echo $products->getAllProducts(Products::ORDER_BY_PRICE);

为什么查询中似乎没有使用 :orderBy 参数?

【问题讨论】:

【参考方案1】:

参数绑定旨在与值一起使用。 ORDER BY 后面实际上是一个字段名,而不是字符串。

【讨论】:

见***.com/questions/2542410/… 对,这里的问题是 pdo 插入的列名是用引号引起来的。

以上是关于为啥 ORDER BY 子句中的绑定参数不对结果进行排序?的主要内容,如果未能解决你的问题,请参考以下文章

为啥在mysql中第一个union两个子句的order by不起作用

五,ORDER BY 子句

SQL语句中,为啥where子句不能使用列别名,而order by却可以?

T-SQL为啥除以零不会在order by子句中产生错误

Sql Server 按偏移量分页行 - 没有'ORDER BY'

SQL Order By 子句详解