php字符串比较搜索仅返回一个条目而不返回正确的条目

时间:2015-12-10 18:41:33

标签: javascript php jquery mysql

我正在使用ajax将搜索字符串发送到执行类似mysql函数的php脚本,以查找所有相关条目,其中包含用于搜索朋友的字符串。我在数据库zukeru和zukeru2中有两个当前条目。当我搜索z我只在我的控制台输出中返回zukeru。当我搜索2我仍然得到zukeru,我真的不知道为什么。

另外如何从php嵌套的tupple中删除特定字段。出于显而易见的原因,我不想包含密码字段。对不起我刚接触php学习,因为我到目前为止它并没有像我想的那样糟糕,有点类似于python。

在搜索数字2时返回对象,但是我得到zukeru而不是zukeru2没有意义。

Object {0: "2", 1: "you wish you could see", 2: "zukeru", 3: "deleted for security", 4: "grant", id: "2", email: "deleted for security", username: "zukeru", password: "deleted for security", name: "grant"}

这是我用于上述结果的搜索字符串。你可以看到我搜索了2并且回到了zukeru而不是zukeru2

profile.php:92 searchstring=2

<?php 
    $db = new mysqli(security reasons removed.);
    extract($_POST);
    //I think i can remove this session start ?
    session_start();
    $serach_string = $_POST['searchstring'];
    $fetch=$db->query("SELECT * FROM users WHERE username LIKE '%$serach_string%'");
    $friends=mysqli_fetch_array($fetch);
    //echo $search_string
    echo json_encode($friends);
?>

这是我想要看到的jquery

  function search(){
        var url = "search_friends.php";       
          $.ajax({
            type: "POST",
              url: url,
               data: $("#search_friends").serialize(), // serializes the form's elements.
                 success: function(data)
                   {   
                    //console.log(data);       
                     var returned_friends = JSON.parse(data); 
                     var html_built = '<br>';
                     console.log(returned_friends);
                     console.log($("#search_friends").serialize());
                     if (returned_friends){ 
                         $.each( returned_friends, function( key, value ) {
                            if (key =="username"){
                                html_built += '<li><a href="#"><button class="btn btn-primary" style="width:100%;" id="'+value+'" onClick="add_friend(this.id)"> Send '+value+' A Friend Request</button></li>';
                            }
                         });
                    }
                    html_built += ""
                     document.getElementById("list_friends").innerHTML = html_built;  

                   }
               });
        return false;
  }

这是我目前正在使用的,我得到了未定义的方法。它找不到fetch_all();和即时通讯使用PHP 5.4

这是返回的控制台错误。

<br />
<b>Fatal error</b>:  Call to undefined method mysqli_result::fetch_all() in <b>/home/gzukel/public_html/search_friends.php</b> on line <b>7</b><br />

<?php 
    $db = new mysqli();
    extract($_POST);
    session_start();
    $serach_string = $_POST['searchstring'];
    if($fetch=$db->query("SELECT username FROM users WHERE username LIKE '%$serach_string%'")){
       $friends=$fetch->fetch_all();
       echo json_encode($friends);
    }else{
       echo 'no results';
    }
?>

2 个答案:

答案 0 :(得分:0)

这样的事情呢?

<?php 
    $db = new mysqli();
    extract($_POST);
    session_start();
    $serach_string = $_POST['searchstring'];
    $fetch=$db->query("SELECT * FROM users WHERE username LIKE '%$serach_string%'");
    $friends=[]

    while($row = $fetch->fetch_array())
    {
        $rows[] = $row;
    }

    foreach($rows as $row)
    {
        array_push($friends,$row['username']);   
    }
    //echo $search_string
    echo json_encode($friends);
?>

答案 1 :(得分:0)

您可以使用fetch all

if($fetch=$db->query("SELECT username FROM users WHERE username LIKE '%$serach_string%'")){

   $friends= $fetch->fetch_all();

   echo json_encode($friends);
}else{
   echo 'no results';
}