donglinyi4313 2014-06-30 15:42
浏览 52
已采纳

INNER JOIN阻止用户和朋友表删除用户

I know that PHP can become quite complex when using INNER JOIN. I've had a play around with a few ideas and nothing seems to be working.

So this is what I'm working towards When user A Blocks user B user B gets removed from their friends.

So I have this and have an error

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'user1_id=15 AND user2_id=3 AND status=1 INNER JOIN friends ON block. DELETE fro' at line 1

Could anyone explain inner join in full and show me where I've gone wrong for future usage.

$query = mysqli_query($mysqli,"INSERT INTO block user1_id=$user1_id AND user2_id=$user2 AND status=1
INNER JOIN friends ON block. 
DELETE from friends where user1_id=$user1_id AND user2_id=$user2 AND status=2 ")
or die (mysqli_error($mysqli));
  • 写回答

2条回答 默认 最新

  • doujianwei8217 2014-06-30 15:59
    关注

    You should use two different statements and you have to use parameterized queries.

    $sql_insert = "INSERT INTO block (user1_id, user2_id, status) values (?,?,1)";    
    $stmt = $mysqli->prepare($sql_insert);
    $stmt->bind_param("s", $user1_id);
    $stmt->bind_param("s", $user2_id);
    if (!$stmt->execute()) {
        echo "Execute failed: (" . $stmt->errno . ") " . $stmt->error;
    }
    
    $sql_delete = "DELETE FROM friends where user1_id=? AND user2_id=? AND status=2 "
    $stmt = $mysqli->prepare($sql_delete);
    $stmt->bind_param("s", $user1_id);
    $stmt->bind_param("s", $user2_id);
    if (!$stmt->execute()) {
        echo "Execute failed: (" . $stmt->errno . ") " . $stmt->error;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)