項目中某個部分需要按照前端頁面選擇的條件進行數(shù)據(jù)庫查詢,如下圖:
我的查詢方法是:
第一步:先根據(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)的呢?
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務(wù)負責iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。