2

这是我的查询

$db2=mysql_connect("localhost","root","");
    mysql_select_db("my_requests",$db2);

    $query=mysql_query("SELECT * FROM details INNER JOIN product ON details.user_id = product.user_id"); // find the city
    $row=mysql_fetch_array($query);// save record

        $id=$row['user_id'];
        echo "$id";


        $query1=mysql_query("DELETE * FROM details WHERE details.user_id=$id");
        $query2=mysql_query("DELETE * FROM product WHERE product.user_id=$id");

这里我有两个表产品和详细信息,用户 ID 是详细信息的主键,并在产品中设置了外键。

假设我在数据库中有两个条目,user_id = 12,另一个条目 user_id = 11 1. 当我采用两个表的内部连接并尝试显示 user_id 时,它只显示一个 user_id 12 2. 当我试图删除数据时使用 user_id,它不会从表中删除数据。

抱歉英语不好

4

2 回答 2

7

查询正确语法DELETE不包括*

DELETE FROM product WHERE product.user_id=$id
//^^^^^^^^^

如果您进行一些基本的错误检查和调试,API 会报告语法错误。

// This query has a syntax error and will return FALSE...
$query1 = mysql_query("DELETE * FROM details WHERE details.user_id=$id");
if (!$query1) {
  // On failure, see what your error was.
  echo mysql_error();
}

上面会报类似如下的错误:

ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以获取在 '* FROM 附近使用的正确语法

于 2012-05-25T12:37:26.660 回答
1

在您的SELECT查询中,您必须指定该表以获得*like details.*or products.*,因为您要连接两个表。在你的情况下,结果是一样的。

您还需要放置$row=mysql_fetch_array($query);在一个循环中,以获取每一行,然后,您的DELETE语法错误:

while($row=mysql_fetch_array($query)) {
    $id=$row['user_id'];
    echo "$id";

    $query1=mysql_query("DELETE FROM details WHERE details.user_id=$id");
    $query2=mysql_query("DELETE FROM product WHERE product.user_id=$id");


}
于 2012-05-25T12:38:18.013 回答