Ошибка PHP var_dump NULL после SQL-запроса

Привет, у меня есть веб-сайт, который запрашивает CarID после того, как пользователь выбирает БРЕНД на веб-странице. Поэтому SELECT запрос будет выполнен и значение CarID будет передано в переменную PHP. Однако в настоящее время var_dump, который я использую для устранения проблемы, дает NULL значение, даже если при выполнении оператора SQL не было ошибок.

Таблица базы данных: введите описание изображения здесь

Коды:

<?php // register.php
session_start();
include "dbconn.php";


$carcat = $_SESSION['selectedcarcat'];
$carbrand = $_POST['carbrand'];
$userid = $_SESSION['loginid'];
$username = $_SESSION['loginname'];
$startdate = $_POST['date1'];
$enddate = $_POST['date2'];
$pick = $_POST['pickuploc'];
$return = $_POST['returnloc'];
$calqty = 0;


    $selcaridsql = "SELECT carid FROM cars WHERE brand='$carbrand' ";
    
    echo $selcaridsql."<br>";

    $caridresult = $dbcnx->query($selcaridsql);

    echo "<br>".var_dump($caridresult);

    if ($caridresult->num_rows >0 )
      {
        echo '<br>Hello more than 1 <br>';  
      }

    else
    {
        echo '<br>Hello less than 1 <br>';
    }


    $caridrow = mysql_fetch_array($caridresult);

    echo var_dump($caridrow)."<br>"; 

    $carid = $caridrow['carid'];

    echo var_dump($carid)."<br>"; 
    
    if (!$caridresult) 
    {
        $errmessage = "Your carid select query failed.";
        echo "<script type='text/javascript'>alert('$errmessage');</script>";
    }


    echo '<br>Debug 1 ';
    echo '<br>The selected qty is '
        .$qtyresult1.'<br />';
    echo '<br>The calculated qty is '
        .$calqty.'<br />';
    echo '<br>The content carid is '
        .$carid.'<br />';
    echo '<br>The content userid is '
        .$userid.'<br />';
    echo '<br>The content start is '
        .$startdate.'<br />';
    echo '<br>The content end is '
        .$enddate.'<br />';
    echo '<br>The content pick is '
        .$pick.'<br />';
    echo '<br>The content return is '
        .$return.'<br />';
        echo '<br>The content carbrand is '
        .$carbrand.'<br />';
?>

Результаты, которые будут в настоящее время выводиться:

SELECT carid FROM cars WHERE brand='Honda' 
object(mysqli_result)#2 (5) { ["current_field"]=> int(0) ["field_count"]=> int(1) ["lengths"]=> NULL ["num_rows"]=> int(1) ["type"]=> int(0) } 

Hello more than 1 
NULL 
NULL 

Debug 1 
The selected qty is 

The calculated qty is 0

The content carid is 

The content userid is 

The content start is 2016-10-28

The content end is 2016-10-29

The content pick is jurong

The content return is bishan

The content carbrand is Honda

Кажется, что запрос может извлечь данные, но я понятия не имею, почему значение будет NULL. Я попробовал оператор SQL непосредственно в базу данных, и он работает.

Благодарю.

1 ответ

Решение

Ваш результат от mysqli_query пока вы пытаетесь получить его с помощью mysql_fetch_array, Попробуйте использовать mysqli_fetch_array для получения результата.

Но будет лучше, если вы используете свой класс БД (тот же, что вы используете для `$dbcnx->query) для получения результата, или если у этого класса нет такого метода, вы можете добавить его.

Другие вопросы по тегам