dongsaolian8786 2012-09-10 22:27
浏览 39
已采纳

ORDER BY不在postgresql中工作

This won't work and i'm getting an error from the ORDER BY param for some reason?

if($selected_radio == 'city')
{
    $query = "SELECT name FROM City WHERE name LIKE $1 LIMIT $2 OFFSET $3 ORDER BY name ASC";
    $result = pg_prepare($conn, "findCity", $query);
    $result = pg_execute($conn, "findCity", array($text, $limit, $offset));

    while($row = pg_fetch_assoc($result))
    {
        echo "<tr>";
        echo "<td>" . $i . "</td>";
        echo "<td>" . $row['name'] . "</td>";
        echo "</tr>";
        $i += 1;
    }
}

Sorry about the way it looks I'm fairly new to this site and not sure how to correctly post code :/

  • 写回答

1条回答 默认 最新

  • drqwbh2150 2012-09-10 22:31
    关注

    You've got your clauses in the wrong order - ORDER BY goes before LIMIT and OFFSET.

    From the docs:

    SELECT [ ALL | DISTINCT [ ON ( expression [, ...] ) ] ]
         * | expression [ AS output_name ] [, ...]
         [ FROM from_item [, ...] ]
         [ WHERE condition ]
         [ GROUP BY expression [, ...] ]
         [ HAVING condition [, ...] ]
         [ { UNION | INTERSECT | EXCEPT } [ ALL ] select ]
         [ ORDER BY expression [ ASC | DESC | USING operator ] [, ...] ]
         [ LIMIT { count | ALL } ]
         [ OFFSET start ]
         [ FOR { UPDATE | SHARE } [ OF table_name [, ...] ] [ NOWAIT ] [...] ]
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 连续两帧图像高速减法
  • ¥15 组策略中的计算机配置策略无法下发
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据
  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写