PHP не повторяет последнюю выборку - PullRequest
1 голос
/ 18 октября 2010

У меня есть этот код:

$result = mysql_query("SELECT * FROM quote ORDER BY RAND() LIMIT 1") or die(mysql_error());  

$row = mysql_fetch_array( $result );

echo $row['frase'];

Это эхо случайное "фраза" каждый раз, когда вы запрашиваете.

Что я хочу сделать, так это избежать одинакового результата в последовательных запросах.

Чтобы было ясно, если в моей базе данных есть:

1   a
2   b
3   c

Если из echo $row['frase']; я получил a, следующий результат не может быть a.

Надеюсь, я дал понять, и если нет, пожалуйста, прокомментируйте, и я буду расширяться!

Заранее спасибо!

Кстати: извините за @deceze @zerkms @ Dr.Molle, потому что последний вопрос был полным беспорядком! Никакого вреда, просто нуб на веселье:)

EDIT:

Чтобы ответить Джейсону МакКрири, я на самом деле называю это так:

<html>
<head>
<script type="text/javascript">
function loadXMLDoc()
{
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET","ajax_info.php",true);
xmlhttp.send();
}
</script>
</head>
<body>

<div id="myDiv"><h2>Let AJAX change this text</h2></div>
<button type="button" onclick="loadXMLDoc()">Change Content</button>

</body>
</html>

1 Ответ

2 голосов
/ 18 октября 2010

Поскольку этот последний запрос должен сохраняться при обновлении страницы, вам необходимо использовать сеанс. Что-то вроде этого:

session_start();

if (empty($_SESSION['lastresult'])) {
    $_SESSION['lastresult'] = null;
}

$query = "SELECT * FROM `quote` WHERE `id` != '%s' ORDER BY RAND() LIMIT 1";
$query = sprintf($query, mysql_real_escape_string($_SESSION['lastresult']));

$result = mysql_query($query) or die(mysql_error());  

$row = mysql_fetch_array($result);

$_SESSION['lastresult'] = $row['id'];

echo $row['frase'];

Возможно, вы захотите сохранить последние x результатов в сеансе и использовать NOT IN () в своем запросе, чтобы избежать повторения каждой второй (третьей, четвертой, ...) кавычки.

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