在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

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

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

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

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

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

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

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

clipboard.png

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

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

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

2017年10月10日 06:34
編輯回答
風畔

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

2018年1月15日 08:24