Php Laravel 5如何使用集合获取多个随机行
基于此,我调整了查询,但仍然没有收到预期的结果 我在数据库中有20篇文章,只想随机获得其中的3篇,并在页面上显示它们 我的课是这样的:Php Laravel 5如何使用集合获取多个随机行,php,random,laravel-5.1,Php,Random,Laravel 5.1,基于此,我调整了查询,但仍然没有收到预期的结果 我在数据库中有20篇文章,只想随机获得其中的3篇,并在页面上显示它们 我的课是这样的: public function article() { $article = DashArticle::where('category', '=', 0)->get()->random(3); $articleTitle0 = $article[0]->titel; $articleAutor0
public function article()
{
$article = DashArticle::where('category', '=', 0)->get()->random(3);
$articleTitle0 = $article[0]->titel;
$articleAutor0 = $article[0]->autor;
$articleAbstract0 = $article[0]->abstract;
$articleSource0 = $article[0]->source;
$articleTitle1 = $article[1]->titel;
$articleAutor1 = $article[1]->autor;
$articleAbstract1 = $article[1]->abstract;
$articleSource1 = $article[1]->source;
$articleTitle2 = $article[2]->titel;
$articleAutor2 = $article[2]->autor;
$articleAbstract2 = $article[2]->abstract;
$articleSource2 = $article[2]->source;
return compact(
'articleTitle0', 'articleAutor0', 'articleAbstract0', 'articleSource0',
'articleTitle1', 'articleAutor1', 'articleAbstract1', 'articleSource1',
'articleTitle2', 'articleAutor2', 'articleAbstract2', 'articleSource2'
);
}
这里是部分观点:
<div id="a-slide" class="carousel slide auto panel-body">
<ol class="carousel-indicators out">
<li class="active" data-slide-to="0" data-target="#a-slide"></li>
<li class="" data-slide-to="1" data-target="#a-slide"></li>
<li class="" data-slide-to="2" data-target="#a-slide"></li>
</ol>
<div class="carousel-inner">
<div class="item active" style="padding: 0 16px;">
<p style="font-size: 16px; font-weight: bold;">{!! $articleTitle0 !!}</p>
<p class="text-muted">{!! $articleAutor0 !!}</p>
<p><strong>Abstract:</strong><br />{!! $articleAbstract0 !!}</p>
<p>
<a href="$articleSource !!}" target="_blank">
{!! $articleSource0 !!}
</a>
</p>
</div>
<div class="item" style="padding: 0 16px;">
<p style="font-size: 16px; font-weight: bold;">{!! $articleTitle1 !!}</p>
<p class="text-muted">{!! $articleAutor1 !!}</p>
<p><strong>Abstract:</strong><br />{!! $articleAbstract1 !!}</p>
<p>
<a href="{!! $articleSource1 !!}" target="_blank">
{!! $articleSource1 !!}
</a>
</p>
</div>
{!!$articletTitle0!!}
{!!$articleAutor0!!}
摘要:
{!!$articleAbstract0!!}
{!!$articletTitle1!!}
{!!$articleAutor1!!}
摘要:
{!!$articleAbstract1!!}
问题是当我让随机数=3时
($article=DashArticle::where('category','=',0)->get()->random(3);
我得到以下错误:“未定义的偏移量:1”
当我user random=20(表中的总行数)时,它可以工作,但我不会成为任何随机项目,而是始终成为表的前3行
如果有任何帮助,我将不胜感激!谢谢!问题是random方法会保留原始集合中的密钥。要避免这种情况,您应该获得纯值:
$article = DashArticle::where('category', '=', 0)->get()->random(3)->values();
问题是random方法保留原始集合中的键。要避免这种情况,您应该获得纯值:
$article = DashArticle::where('category', '=', 0)->get()->random(3)->values();
您可以通过以下方式获得随机行:
public function article()
{
$article = DashArticle::orderBy(DB::raw('RAND()'))->take(3)->get();
//pass data to view
if(view()->exists('article.list')){
return view('article.list',compact('article'));
}
}
您可以通过以下方式获得随机行:
public function article()
{
$article = DashArticle::orderBy(DB::raw('RAND()'))->take(3)->get();
//pass data to view
if(view()->exists('article.list')){
return view('article.list',compact('article'));
}
}
试试这个
$article = DashArticle::where('category', '=', 0)->get()->shuffle()->all();
试试这个
$article = DashArticle::where('category', '=', 0)->get()->shuffle()->all();