2017-07-03 91 views
2

获取最后25行的表的我目前转移我的网站laravel,我有打开下面的SQL进入雄辩问题:用雄辩

(SELECT * FROM `messages` WHERE `lobby`='$lobbyid' AND `timestamp` > '1' ORDER BY id DESC LIMIT 25) order by id' 

我曾尝试:

return DB::table('messages') 
       ->select('*') 
       ->where('lobby', $lobbyid) 
       ->where('timestamp', '>', 1) 
       ->orderby('id', 'desc') 
       ->limit(25) 
       ->orderby('id') 
       ->get(); 

但第二个order by只是被忽略。如标题所示,此查询旨在获取特定大厅聊天的最后25条消息。 SQL本身的作品我只是需要帮助转换成雄辩如果可能的话。

+0

您只能使用一个'order by'。在这种情况下,您只需要一个:第一个'order by'返回记录的顺序与第二个'order by'的顺序相同 –

+1

这可能会变得很难看,因为您可能需要在这里使用原始子查询。 –

+0

@NorbertvanNobelen正确,但第一部分'SELECT * FROM messages WHERE lobby ='$ lobbyid'AND timestamp>'1'ORDER BY id DESC LIMIT 25'实际上得到最后25条消息......问题在于更高的id首先出现。较高的ID应该是最后的,因为它们是较新的消息。 – Shawn31313

回答

1

我认为你需要从查询25分的结果,然后在PHP重新排序阵列

$result = DB::table('messages') 
       ->select('*') 
       ->where('lobby', $lobbyid) 
       ->where('timestamp', '>', 1) 
       ->orderby('id', 'desc') 
       ->limit(25) 
       ->get(); 

重排阵:

$result= array_sort($result , 'id', SORT_ASC); 

function array_sort($array, $on, $order=SORT_ASC){ 

    $new_array = array(); 
    $sortable_array = array(); 

    if (count($array) > 0) { 
     foreach ($array as $k => $v) { 
      if (is_array($v)) { 
       foreach ($v as $k2 => $v2) { 
        if ($k2 == $on) { 
         $sortable_array[$k] = $v2; 
        } 
       } 
      } else { 
       $sortable_array[$k] = $v; 
      } 
     } 

     switch ($order) { 
      case SORT_ASC: 
       asort($sortable_array); 
       break; 
      case SORT_DESC: 
       arsort($sortable_array); 
       break; 
     } 

     foreach ($sortable_array as $k => $v) { 
      $new_array[$k] = $array[$k]; 
     } 
    } 

    return $new_array; 
} 

或者使用将使用Laravel原始查询:

DB::raw((SELECT * FROM `messages` WHERE `lobby`='$lobbyid' AND `timestamp` > '1' ORDER BY id DESC LIMIT 25) order by id') 
0

您应该使用Eloquent查询来尝试此操作:

Message::where('lobby', $lobbyid) 
     ->where('timestamp', '>', 1) 
     ->orderBy('id', 'desc') 
     ->take(25) 
     ->get(); 

注意:消息是型号名称。