gpt4 book ai didi

php - 从 mysql 查询中打印随机行

转载 作者:可可西里 更新时间:2023-11-01 07:01:36 24 4
gpt4 key购买 nike

我一直在寻找一种创建协作翻译小部件的方法。所以我有一个 mysql 数据库和表(称为翻译),以及一个允许用户一次翻译一页的小脚本。

但我不太相信我的剧本。我认为它不够有效。首先,mysql 获取所有“en”列为空的行,然后一段时间后屏幕显示其中的一个。还有其他方法吗?这是代码:

//Retrieve all the data from the "translations" table
$result = mysql_query("SELECT * FROM translations WHERE en IS NULL OR en=''") or die(mysql_error());

$Randnum=rand(0,mysql_num_rows($result)-1); //Gets a random number between 0 and the maximum number of rows
$i=0; //Start to 0
while($Col = mysql_fetch_array($result)) //While there are rows to evaluate
{
if ($i==$Randnum)
{
echo "\"".$Col['es']."\"<br><br>Translate it to English: <br>";
}
$i++;
}

我一直在寻找类似“echo $Col[$Randnum]['es']”或“echo $Col.$Randnum['es']”的东西,而不是使用整个 while 循环来打印一个单个随机行。我该如何实现? 如果这只是一个优化问题。如果您可以提供一个脚本或想法,将一行随机数和空的“en”col 分配给 $Col,那就更好了! (我认为这最后一点是不可能的)。 “en”行是文本,所以我不知道如何实现 other methods我看到他们在 ORDER BY 中使用数字。

最佳答案

您可以在查询中使用 ORDER BY RAND() LIMIT 1 从数据库中获取单个随机行。

关于php - 从 mysql 查询中打印随机行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9967348/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com