3

我已经坚持了一段时间,我知道非常初学者,但找不到任何类似的问题。

我正在尝试显示我上一个主题的详细信息,但我收到了警告。

*Warning: pg_exec() [<a href='function.pg-exec'>function.pg-exec</a>]:
Query failed: 
ERROR: operator does not exist: character varying = integer LINE 4: WHERE
t_cat = 3 ^
HINT: No operator matches the given name and argument type(s). You
might need to add explicit type casts.*

任何帮助表示赞赏

$topicsearh = pg_exec($db, 
     "SELECT t_id, t_subject, t_date, t_cat
      WHERE t_cat = " . $row['s_id'] . "
      ORDER BY t_date DESC LIMIT 1"
);      
if(!$topicsearh){
          echo 'Last topic could not be displayed.';
}
else{
      while($trow = pg_fetch_assoc($topicsearh))
      echo '<a href="topicview.php?id=' . $trow['t_id'] . '">' . $trow['t_subject'] .   
          '</a> at ' . date('d-m-Y', strtotime($trow['t_date']));
}
4

2 回答 2

3

您需要定义FROM表。

例子

SELECT t_id, t_subject, t_date, t_cat FROM TABLE_NAME WHERE...
                            ----------^^^^^^^^^^^^^^^-----

以及如下所示的 con-cat。

WHERE t_cat = '". $row['s_id'] ."'
于 2013-03-30T04:36:53.103 回答
2

虽然@Dipesh 关于缺少的FROM子句是正确的,但手头的错误指向您查询中的另一个问题。t_cat显然是类型character varying。因此,您必须将其与匹配的字符串常量进行比较。但是您正在提交一个没有单引号的数字常量。

PHP(或 MySQL)传统上倾向于默默地吞下这些错误并做他们认为“最好的”(这不是他们能做的最好的)。幸运的是,PostgreSQL 没有。它迫使你毫不含糊。

应该:

WHERE t_cat = '" . $row['s_id'] . "' ORDER BY t_date DESC LIMIT 1"

代替:

WHERE t_cat = " . $row['s_id'] . " ORDER BY t_date DESC LIMIT 1"

阅读手册中的常量一章,特别是字符串常量数值常量

于 2013-03-30T06:52:32.373 回答