1. 程式人生 > >PHP無限循環取MySQL中的數據。

PHP無限循環取MySQL中的數據。

public log query 開始 ret 無限循環 展示 test urn

  最近公司有個需求需要從MySQL獲取數據,然後在頁面上無線循環的翻頁展示。主要就是一直點擊一個按鈕,然後數據從最開始循環到末尾,如果末尾的數據不夠了,那麽從數據的最開始取幾條補充上來。

  其實,這個功能可以通過JS+PHP實現,也可以通過PHP + MYSQL+JS實現,只不過JS+PHP比較方便而且效率更高罷了。

  下面是PHP + MYSQL+JS實現辦法。

  每次顯示10條數據。

1 public function get_data($limit){
2       $sql="select * from ((select id,name from `mytable` limit {$limit
},10) union all (select id,name from `mytable` limit 0,10)) as test limit 0,10"; 3    return $this->query($sql); 4 }

  上述sql語句通過mysql的union all方法,把兩個集合拼接到一起,並取前十條數據。

1  public function getCount(){//獲取數據的條數
2         $sql="select count(id) as t from `mytable`";
3         return $this->query($sql);
4 }

  下一步在控制器中獲取數據,並給ajax提供數據接口。

 1  //測試數據庫無限循環取數據
 2      public function getInfiniteData(){
 3         //用戶點擊數
 4         $page = $_GET[‘click‘];
 5      //每次展示條數
 6         $pagesize = 10;
 7      //獲取總條數
 8         $total = $this->Mydemo->get_count();
 9         $t = $total[0][0][‘t‘];
10      //算出每次點擊的其起始位置
11 $limit = (($page - 1)*$pagesize)%$t; 12 13 $data = $this->Mydemo->get_data($limit); 14 15 if (!empty($data)) { 16 //轉換為二維數組 17 $list = []; 18 foreach ($data as $key => $v) { 19 $list[$key] = $data[$key][0]; 20 } 21 22 $info[‘msg‘] = $list; 23 $info[‘code‘] = ‘001‘; 24 }else{ 25 $info[‘code‘] = ‘002‘; 26 $info[‘msg‘] = ‘暫無數據‘; 27 } 28 echo json_encode($info,JSON_UNESCAPED_UNICODE);die; 29 30 }

JS代碼我就不貼了。

  

PHP無限循環取MySQL中的數據。