0

我有一个具有以下结构的表,

    FIELD           TYPE          EXTRA
faciltiy_id         int          auto_increment(Primary Key)
hotel_id            int
facility_title      varchar(20)
facility_desc      varchar(300)

当我想删除特定行时,facility_id我使用代码,

DELETE 
FROM   $hotel_facilities
WHERE  facilities_id = '$facilities_id'";

但不是整行,只有facility_titleandfacility_desc字段被删除。如果我直接通过 phpmyadmin 在表上运行此查询,则它可以正常工作。

谁能告诉我我做错了什么?

4

1 回答 1

1

但不是整行,只有 facility_title 和 facility_desc 字段被删除。如果我直接通过 phpmyadmin 在表上运行此查询,它可以正常工作......

因为facilities_id是一个 INT,所以你不需要用单引号将它括起来:

DELETE FROM {$hotel_facilities}
 WHERE facilities_id = {$facilities_id}

但我认为真正的问题是正在调用 UPDATE 语句,而不是 DELETE 语句。主要是因为 DELETE 语句只删除整行,而不是特定列。

您需要跟踪触发提交时调用的内容,并在执行之前打印到屏幕(使用echo或通过 Javascript,如果更方便的话)。

于 2010-01-11T04:44:03.187 回答