Почему я получаю дубликаты из запроса MySQL? - PullRequest
2 голосов
/ 30 июня 2011

Я использую Ajax-вызов PHP-файла для получения данных из базы данных MySQL и заполнения опций выбора в HTML.Проблема в том, что в опциях дублируются элементы, и я не знаю почему.Я попробовал запрос в верстаке, и он возвращает то, что мне нужно.

PHP-файл:

<?php
    $q=$_GET["q"];

   // open db connection code

   $query = "select * from r2rtool.materialtype where type = 'FE' and tools like '%".$q."%'";
   $result = mysql_query($query);

   $option = "";

   while($row = mysql_fetch_array($result))
    {
        $mat = $row["Material"];
        $option.="<option value=\"$mat\">".$mat."</option>";

        echo $option;
    }

   // close db connection
?>

Функция Ajax:

function populatematerial(str)
{
    if (str=="") {
      document.getElementById("txtHint").innerHTML="";
      return;
    }

    if (window.XMLHttpRequest) {
      // IE7+, Firefox, Chrome, Opera, Safari
      xmlhttp=new XMLHttpRequest();
    }

    else{
      // IE6, IE5
      xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }

    xmlhttp.onreadystatechange=function()
    {
      if (xmlhttp.readyState==4 && xmlhttp.status==200) {
        document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
      }
    }

    xmlhttp.open("GET","phpfile.php?q="+str,true);
    xmlhttp.send();
}

Ответы [ 3 ]

6 голосов
/ 30 июня 2011
while($row = mysql_fetch_assoc($result))
{
     $option .= "<option value=\"{$row[Material]}\">{$row[Material]}</option>";
}
echo $option;
1 голос
/ 30 июня 2011

Все, что вам нужно сделать, это вывести echo $option; из цикла while, например:

while($row = mysql_fetch_array($result))
{
    $mat = $row["Material"];
    $option.="<option value=\"$mat\">".$mat."</option>";
}
echo $option;

Вы должны выводить HTML после того, как вы его построили, а не во время его построения.

0 голосов
/ 26 июня 2013

используйте mysql_fetch_assoc вместо mysql_fetch_array, потому что массив возвращает значение в числах и называет оба формата, поэтому он будет удваивать данные,

где mysql_fetch_assoc возвращает массив как единственный элемент имени массива ..

для большего понимания попробуйте

<?php 
$query = mysql_query("some query ");
$row = mysql_fetch_array($row);
$assoc = mysql_fetch_array($row);
print_r ($row);
echo "<br>";
print_r ($assoc);
echo "<br>";
?>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...