表的結(jié)構(gòu)再簡單,也架不住數(shù)據(jù)量龐大啊。只有2個字段的表,查詢語句上好像也做不出什么優(yōu)化。個人想法是,防偽碼不會經(jīng)常被查。一般一個防偽碼被查個兩三次就差不多了吧,是否可以考慮把建立時間較久遠(yuǎn)的防偽碼去除,只保留一段時間以內(nèi)的?;蛘甙葱蛄刑杽?chuàng)建時間分表存儲數(shù)據(jù),時間較為久遠(yuǎn)的數(shù)據(jù)單獨(dú)放一張表;近期的新序列號放在另一張表,增加序列號生成時間字段。但凡在一定的創(chuàng)建時間之前的老序列號,就去查老表老數(shù)據(jù),否則就查新表新數(shù)據(jù)。序列號的生成應(yīng)該是有規(guī)律的吧,大數(shù)據(jù)只能分表來提升查詢效率。
創(chuàng)新互聯(lián)擁有網(wǎng)站維護(hù)技術(shù)和項(xiàng)目管理團(tuán)隊(duì),建立的售前、實(shí)施和售后服務(wù)體系,為客戶提供定制化的成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、網(wǎng)站維護(hù)、服務(wù)器機(jī)柜租賃解決方案。為客戶網(wǎng)站安全和日常運(yùn)維提供整體管家式外包優(yōu)質(zhì)服務(wù)。我們的網(wǎng)站維護(hù)服務(wù)覆蓋集團(tuán)企業(yè)、上市公司、外企網(wǎng)站、商城網(wǎng)站建設(shè)、政府網(wǎng)站等各類型客戶群體,為全球上1000+企業(yè)提供全方位網(wǎng)站維護(hù)、服務(wù)器維護(hù)解決方案。
使用子查詢優(yōu)化大數(shù)據(jù)量分頁查詢
這種方式的做法是先定位偏移位置的id,然后再往后查詢,適用于id遞增的情況。
使用id限定優(yōu)化大數(shù)據(jù)量分頁查詢
使用這種方式需要先假設(shè)數(shù)據(jù)表的id是連續(xù)遞增的,我們根據(jù)查詢的頁數(shù)和查詢的記錄數(shù)可以算出查詢的id的范圍,可以使用 id between and 來查詢:
當(dāng)然了,也可以使用in的方式來進(jìn)行查詢,這種方式經(jīng)常用在多表關(guān)聯(lián)的情況下,使用其他表查詢的id集合來進(jìn)行查詢:
但是使用這種in查詢方式的時候要注意的是,某些MySQL版本并不支持在in子句中使用limit子句。
參考 sql優(yōu)化之大數(shù)據(jù)量分頁查詢(mysql) - yanggb - 博客園 (cnblogs.com)
查詢大量數(shù)據(jù)的,如果出現(xiàn)如下情況,就說明最大內(nèi)存已經(jīng)耗盡:
可臨時修改腳本使用內(nèi)存大小進(jìn)行處理:
注意:
當(dāng)使用libmysqlclient作為庫時,PHP的內(nèi)存限制將不會計算用于結(jié)果集的內(nèi)存,除非將數(shù)據(jù)讀入PHP變量。與mysqlnd的內(nèi)存占用將包括完整的結(jié)果集。
由于緩沖查詢是默認(rèn)的,下面的示例將演示如何使用每個API執(zhí)行無緩沖的查詢。