首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >随机排列MYSQL结果

随机排列MYSQL结果
EN

Stack Overflow用户
提问于 2012-02-27 04:51:52
回答 4查看 20K关注 0票数 7

下面的代码显示随机的数据库图像以及一个特定的图像(这就是我想要的)。我如何在数据库查询后混洗这些结果,因为图像ID 11总是首先显示?我希望图像ID 11在其他图像中随机显示。

我可以使用SHUFFLE()吗?如果是这样的话,我现在到底应该把它放在哪里?

任何帮助都将被视为仍在学习PHP

谢谢。

代码语言:javascript
运行
复制
<?php 

mysql_connect("", "", "") or die(mysql_error()) ; 
mysql_select_db("images") or die(mysql_error()) ;


$photo=mysql_query("SELECT * FROM `profile_images` ORDER BY (ID = 11) DESC, RAND()      
LIMIT 7");


while($get_photo=mysql_fetch_array($photo)){ ?>

<div style="width:300px;">


<img src="<? echo $get_photo['url']; ?>">


</div>

<? } ?>
EN

Stack Overflow用户

回答已采纳

发布于 2012-02-27 04:57:05

您可以在将它们检索到php之后对它们进行混洗。

代码语言:javascript
运行
复制
$photos = array();
while ($get_photo = mysql_fetch_array($photo))
    $photos[] = $get_photo;

shuffle($photos);

或者,您可以使用子查询完成此操作:

代码语言:javascript
运行
复制
SELECT A.* FROM (
    SELECT * FROM `profile_images` 
    ORDER BY (ID = 11) DESC, RAND()      
    LIMIT 7
) as A
ORDER BY RAND()
票数 12
EN
查看全部 4 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9457029

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档