Не получая результатов для поиска в php и mysqli - PullRequest
0 голосов
/ 28 мая 2018

Я не понимаю, почему я не получаю никаких результатов в этом коде, каждый раз, когда я запускаю его, запускается оператор else.

<?php 
            if(isset($_POST['search'])){
                    $search = mysqli_real_escape_string($connection, $_POST['user_query']);

            $sql = "SELECT * FROM search WHERE search_title LIKE '%user_query%' OR search_desc LIKE '%user_query%' OR search_key LIKE '%user_query%' ";
            $run = mysqli_query($connection, $sql);
            $queryResult = mysqli_num_rows($run);


        if($queryResult > 0){
            while($rel_rows = mysqli_fetch_assoc($queryResult)){
                echo "<div id='post'>
            <a href='#'><img src='$rel_rows[search_img]'></a>
            <a href='#'><h4 class='post_name'>$rel_rows[search_title]</h4></a>
            <p class='post_info'> $rel_rows[search_desc]</p>
        </div>";
            }
        }
        else{

            echo "There are no results for your search";
        }

            }
         ?>

Ответы [ 2 ]

0 голосов
/ 28 мая 2018

Попробуйте

  <?php 
                if(isset($_POST['search'])){
                        $search = mysqli_real_escape_string($connection, $_POST['user_query']);
$user_query=$search; 
//Added this line and replace user_query to $user_query in SQL query statement    
                $sql = "SELECT * FROM search WHERE search_title LIKE '%$user_query%' OR search_desc LIKE '%$user_query%' OR search_key LIKE '%$user_query%' ";
                $run = mysqli_query($connection, $sql);
                $queryResult = mysqli_num_rows($run);


            if($queryResult > 0){
                while($rel_rows = mysqli_fetch_assoc($run)){
                    echo "<div id='post'>
                <a href='#'><img src='$rel_rows[search_img]'></a>
                <a href='#'><h4 class='post_name'>$rel_rows[search_title]</h4></a>
                <p class='post_info'> $rel_rows[search_desc]</p>
            </div>";
                }
            }
            else{

                echo "There are no results for your search";
            }

                }
             ?>

Надеюсь, это поможет !!

0 голосов
/ 28 мая 2018

Вы передаете неправильную строку поиска;

Изменить на:

$sql = "SELECT * FROM search WHERE search_title LIKE '%$search%' OR search_desc LIKE '%$search%' OR search_key LIKE '%$search%' ";

Вы передаете неверную переменную в качестве параметра в mysqli_fetch_assoc (..)

Изменить на:

mysqli_fetch_assoc($run)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...