鍍金池/ 問答/PHP/ laravel 數(shù)據(jù)庫(kù)查詢數(shù)據(jù)量較大如何優(yōu)化?

laravel 數(shù)據(jù)庫(kù)查詢數(shù)據(jù)量較大如何優(yōu)化?

項(xiàng)目中某個(gè)部分需要按照前端頁(yè)面選擇的條件進(jìn)行數(shù)據(jù)庫(kù)查詢,如下圖:
clipboard.png

我的查詢方法是:
第一步:先根據(jù)地點(diǎn)、時(shí)間等條件拿到所有符合的結(jié)果,(不加入人員屬性的條件)
第二步:然后再遍歷這個(gè)集合,從中挑選出所有符合我人員屬性的結(jié)果,此處人員屬性是可以多選的,而且要查出的是包含我所選擇屬性的所有結(jié)果。

按照這個(gè)方法進(jìn)行查詢獲得數(shù)據(jù)總量大約在4萬條左右,這時(shí)候php會(huì)報(bào)錯(cuò):
Allowed memory size of 134217728 bytes exhausted (tried to allocate 4194304 bytes)
根據(jù)報(bào)錯(cuò)信息,大概是我查詢的數(shù)據(jù)據(jù)兩在內(nèi)存中所占用的空間太大,超出了php默認(rèn)的128M內(nèi)存。
也就是說,當(dāng)?shù)谝徊酵瓿珊?,此時(shí)所有數(shù)據(jù)已經(jīng)超出內(nèi)存限制了。。。

有以下幾個(gè)問題請(qǐng)問各位大佬指點(diǎn):
1.除了增加php默認(rèn)內(nèi)存(比如改為512M的確可以解決這個(gè)問題),還有其他方法嘛?因?yàn)楦杏X這個(gè)方法治標(biāo)不治本?。?br>2.有沒有更好的查詢邏輯呢?我的邏輯總結(jié)下就先查出所有的結(jié)果在進(jìn)行篩選,有沒有可能把人員屬性篩選條件也加進(jìn)去一起查出來再進(jìn)行分頁(yè)操作呢?如果可以加進(jìn)去,怎么做呢?

ps:我看京東或淘寶這種電商網(wǎng)站也存在對(duì)某個(gè)屬性進(jìn)行多選的篩選情況,不知道他們是怎么實(shí)現(xiàn)的呢?

clipboard.png

回答
編輯回答
雨萌萌
第一步:先根據(jù)地點(diǎn)、時(shí)間等條件拿到所有符合的結(jié)果,(不加入人員屬性的條件)
第二步:然后再遍歷這個(gè)集合,從中挑選出所有符合我人員屬性的結(jié)果,此處人員屬性是可以多選的,而且要查出的是包含我所選擇屬性的所有結(jié)果。

從你的這個(gè)描述邏輯來看,沒人會(huì)把幾萬條數(shù)據(jù)查詢出來放在內(nèi)存中的,這樣內(nèi)存溢出很正常。

目前我們的電商系統(tǒng),都是構(gòu)造好所有查詢參數(shù),再去數(shù)據(jù)庫(kù)分頁(yè)取數(shù)據(jù),同時(shí)對(duì)查詢條件和結(jié)果進(jìn)行緩存處理。

2017年10月10日 06:34
編輯回答
風(fēng)畔

那就不是用Laravel做的撒
這么大型的網(wǎng)站

2018年1月15日 08:24