php 查询数据是否大于,怎么实现从数据查询数据的时候判断如果数据大于N条分次查询 递归吗?...
比如數(shù)據(jù)庫(kù)有300000條數(shù)據(jù) 現(xiàn)在根據(jù)條件查詢符合的有30000條數(shù)據(jù) 一次取太多了可能慢或者其他問(wèn)題 我想每次取10000 三次取完 這只是個(gè)例子 應(yīng)該怎么實(shí)現(xiàn)啊?用遞歸嗎?
告知下 謝謝!!!
還有就是如果查倆張表的數(shù)據(jù) 合并在一起 還有辦法排序嗎根據(jù)某個(gè)字段?
回復(fù)內(nèi)容:
比如數(shù)據(jù)庫(kù)有300000條數(shù)據(jù) 現(xiàn)在根據(jù)條件查詢符合的有30000條數(shù)據(jù) 一次取太多了可能慢或者其他問(wèn)題 我想每次取10000 三次取完 這只是個(gè)例子 應(yīng)該怎么實(shí)現(xiàn)啊?用遞歸嗎?
告知下 謝謝!!!
還有就是如果查倆張表的數(shù)據(jù) 合并在一起 還有辦法排序嗎根據(jù)某個(gè)字段?
謝邀,對(duì)于數(shù)據(jù)量較大的結(jié)果集,我目前一般采用以下兩種方式處理。采用這兩種方式處理的目的就是:一是減少數(shù)據(jù)集獲取時(shí)帶寬資源的占用,二是減少程序?qū)Y(jié)果集處理時(shí)內(nèi)存的使用。
分塊,就是題主的思路
$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));
游標(biāo),按行讀取返回
$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));
個(gè)人建議當(dāng)你要查找后面的分塊的時(shí)候,用where條件而不是直接limit 100000 , 100000:
二者區(qū)別舉例如下:
//這個(gè)是第一種,取第20w開(kāi)始的10w條數(shù)據(jù)
select * from table limit 100000 , 100000 order by id
//這是第二種取法
select * from table where id > 100000 limit 100000 order by id
因?yàn)閙ysql用limit越往后,排序之后取后面的越慢
直接通過(guò)sql語(yǔ)句就能搞定呀,不需要后臺(tái)處理;可以排序呀,根據(jù)你指定字段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 條件。看看一共有多少數(shù)據(jù)。大于N條的時(shí)候,
你再select * from table limit m,n 分頁(yè)查詢
2張表的話就
select * from table1 union all select * form table2 order by 某個(gè)字段。注意查詢的列數(shù)量要一樣。最好類型也一樣
假設(shè)表id均勻分布的情況下,可以利用ID的區(qū)間來(lái)分段查詢數(shù)據(jù)
//每次計(jì)劃讀取的數(shù)據(jù)條數(shù)
$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區(qū)間
$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})";
//得到數(shù)據(jù)之后的操作
//.........
//重新計(jì)算下一次的ID區(qū)間
$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;
}
}
本文原創(chuàng)發(fā)布php中文網(wǎng),轉(zhuǎn)載請(qǐng)注明出處,感謝您的尊重!
總結(jié)
以上是生活随笔為你收集整理的php 查询数据是否大于,怎么实现从数据查询数据的时候判断如果数据大于N条分次查询 递归吗?...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: php中怎样表示组合框,php – 如何
- 下一篇: ctf php sql注入,CTF—攻防