dongwuxie5112 2016-02-14 15:38
浏览 51

基本的php mysqli :: query()不起作用

    $query = "SELECT webpage_id FROM s_w WHERE s_w_id=? LIMIT 1";
    $stmt = $connect->prepare($query);
    $stmt->bind_param("i", $s_w_id);
    $stmt->execute();
    $stmt->bind_result($webpage_id);

while($stmt->fetch()){
        echo $webpage_id;  //it echos ot $webpage_id correctly which means my prepared statement works

        $query2 = "INSERT INTO webpage_point (webpage_id, point_ip) VALUES ($webpage_id, '$ip')";
        $connect->query($query2); // however this code does not work. It does not insert anything into webpage_point. Whats wrong with this basic line?
}

Note that: i am getting $ip(varchar(50)) correctly. I am sure about that too. Just two basic line and it drives me mad.

VERY IMPORTANT EDIT: I changed my prepared statement with a normal query and it worked.

    $query = "SELECT webpage_id FROM s_w WHERE s_w_id=$s_w_id LIMIT 1";
    $result = $connect->query($query);


while($row = $result->fetch_array()){
        $webpage_id = $row['webpage_id'];

        $query = "INSERT INTO webpage_point (webpage_id, point_ip) VALUES ($webpage_id, '$ip')";
        $connect->query($query);
}

So there is something wrong about mysqli prepared statements.

  • 写回答

2条回答 默认 最新

  • dqs86517 2016-02-14 15:52
    关注

    You are only fetching and inserting 1 row, so you don't really need 2 sql statements and a loop.

    What you could do, is something like:

    INSERT INTO webpage_point (webpage_id, point_ip)
    SELECT webpage_id, '$ip' FROM s_w WHERE s_w_id=? LIMIT 1"
    

    Note that you should bind the second variable - $ip - as well, this is just to show the complete sql in an easy way.

    评论

报告相同问题?

悬赏问题

  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效