我有这个代码:
$result = mysql_query("SELECT * FROM quote ORDER BY RAND() LIMIT 1") or die(mysql_error());
$row = mysql_fetch_array( $result );
echo $row['frase'];
每次您查询时,它都会回显一个随机的“frase”。
我想做的是避免在连续查询中出现相同的结果。
为了清楚起见,如果我的数据库中有:
1 a
2 b
3 c
如果来自 echo $row['frase'];
我得到了 a
下一个结果不能是a
.
我希望我说清楚了,如果没有请发表评论,我会展开!
提前致谢!
顺便说一句:对@deceze @zerkms @Dr.Molle 表示抱歉,因为最后一个问题一团糟!没有伤害,只是狂欢中的菜鸟 :)
编辑:
为了回答 Jason McCreary,我实际上是这样调用它的:
<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>
最佳答案
由于最后一个查询需要在页面刷新时保持不变,因此您需要使用 session 。沿着这些线的东西:
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 个结果存储在 session 中并在查询中使用 NOT IN ()
以避免每一秒(第三次、第四次……)引用相同。
关于PHP 不重复上次获取,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3956147/