php 查询数据是否大于,怎么实现从数据查询数据的时候判断如果数据大于N条分次查询 递归吗?...
比如數據庫有300000條數據 現在根據條件查詢符合的有30000條數據 一次取太多了可能慢或者其他問題 我想每次取10000 三次取完 這只是個例子 應該怎么實現啊?用遞歸嗎?
告知下 謝謝!!!
還有就是如果查倆張表的數據 合并在一起 還有辦法排序嗎根據某個字段?
回復內容:
比如數據庫有300000條數據 現在根據條件查詢符合的有30000條數據 一次取太多了可能慢或者其他問題 我想每次取10000 三次取完 這只是個例子 應該怎么實現啊?用遞歸嗎?
告知下 謝謝!!!
還有就是如果查倆張表的數據 合并在一起 還有辦法排序嗎根據某個字段?
謝邀,對于數據量較大的結果集,我目前一般采用以下兩種方式處理。采用這兩種方式處理的目的就是:一是減少數據集獲取時帶寬資源的占用,二是減少程序對結果集處理時內存的使用。
分塊,就是題主的思路
$sql = 'SELECT xxx FROM table WHERE xxx LIMIT limit :limit offset :offset';
$limit = 10000;
$offset = 0;
do{
$stmt = $dbh->prepare($sql, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY));
$stmt->execute(array(':limit' => $limit, ':offset' => $offset));
$data = $stmt->fetchAll();
// 處理邏輯
$offset += $limit;
}while(count($data));
游標,按行讀取返回
$sql = 'SELECT xxx FROM table WHERE xxx';
$stmt = $dbh->prepare($sql, array(PDO::ATTR_CURSOR => PDO::CURSOR_SCROLL));
$stmt->execute();
$row = $stmt->fetch(PDO::FETCH_NUM, PDO::FETCH_ORI_LAST);
do {
// 處理邏輯 $row
} while ($row = $stmt->fetch(PDO::FETCH_NUM, PDO::FETCH_ORI_PRIOR));
個人建議當你要查找后面的分塊的時候,用where條件而不是直接limit 100000 , 100000:
二者區別舉例如下:
//這個是第一種,取第20w開始的10w條數據
select * from table limit 100000 , 100000 order by id
//這是第二種取法
select * from table where id > 100000 limit 100000 order by id
因為mysql用limit越往后,排序之后取后面的越慢
直接通過sql語句就能搞定呀,不需要后臺處理;可以排序呀,根據你指定字段order by就行了
連表查詢
例如:SELECT a.* from tableA as a, tableB as b where a.id = b.id order by a.id desc limit 0,10000";
你可以先select count(1) from table where 條件。看看一共有多少數據。大于N條的時候,
你再select * from table limit m,n 分頁查詢
2張表的話就
select * from table1 union all select * form table2 order by 某個字段。注意查詢的列數量要一樣。最好類型也一樣
假設表id均勻分布的情況下,可以利用ID的區間來分段查詢數據
//每次計劃讀取的數據條數
$max_per_size = 10000;
//找到符合條件的最小ID和最大ID
$sql = "SELECT min(id),max(id) AS max_id AS num FROM `table` WHERE xx='xx'";
$stmt = $pdo->prepare($sql);
$stmt->execute();
$res = $stmt->fetch(PDO::FETCH_ASSOC);
//符合條件的最大ID
$max_id = $res['max_id'];
//符合條件的最小ID
$min_id = $res['min_id'];
$times = ceil(($max_id - $min_id + 1) / $max_per_size);
//第一次的ID區間
$current_min_id = $min_id;
$current_max_id = $min_id + $max_per_page;
for($i = 0; $i= {$current_min_id} AND id <= {$current_max_id})";
//得到數據之后的操作
//.........
//重新計算下一次的ID區間
$current_min_id = $current_max_id + 1;
$current_max_id = $current_max_id + $max_per_page;
if ($current_max_id > $max_id) {
$current_max_id = $max_id;
}
}
本文原創發布php中文網,轉載請注明出處,感謝您的尊重!
總結
以上是生活随笔為你收集整理的php 查询数据是否大于,怎么实现从数据查询数据的时候判断如果数据大于N条分次查询 递归吗?...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php中怎样表示组合框,php – 如何
- 下一篇: ctf php sql注入,CTF—攻防