1、解決這個問題,首先需要查看你的程序是否分配了過多的內(nèi)存,在程序沒有問題的情況下,你可以通過一下方法來增加PHP的內(nèi)存限制(memory_limit)。
專注于為中小企業(yè)提供做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)城區(qū)免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了超過千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
2、來個100人同時點(diǎn),你要用的是普通的虛擬機(jī)就不行了。最好是換種方式實(shí)現(xiàn),不要通過網(wǎng)頁進(jìn)行采集??梢苑浅:唵蔚脑跀?shù)據(jù)庫的表,創(chuàng)建一個采集隊(duì)列,后臺執(zhí)行一個crontab的計(jì)劃任務(wù),去完成隊(duì)列里的采集任務(wù)。
3、要分層次顯示,另外碰到數(shù)據(jù)庫查詢文字非常多的你還可以使用AJAX 返回?cái)?shù)據(jù) 這樣HTML就可以很快的顯示 顯示完畢才去讀數(shù)據(jù)庫這樣速度會快很多。至于樓上說的 緩存 數(shù)據(jù)庫存儲過程 可以參考一下,不過一般企業(yè)站不需要考慮。
4、而且如果使用mysql的話,它也有一個超時時間,運(yùn)行一串代碼時間如果超過配置文件的時間,會被中斷不運(yùn)行。第一種你可以修改php配置文件timeout的運(yùn)行時間,第二你可以分批處理大量數(shù)據(jù),注意是分批處理,就OK了。
5、使用緩存,比如memcache,redis,因?yàn)樗鼈兪窃趦?nèi)存中運(yùn)行,所以處理數(shù)據(jù),返回?cái)?shù)據(jù)非???,所以可以應(yīng)對高并發(fā)。
php使用的數(shù)據(jù)庫一般是mysql,當(dāng)數(shù)據(jù)量大于1000萬時,為了效率最好還會進(jìn)行分表存儲。
個人建議還是拆分的比較好,一次查詢雖然寫法上可能會省代碼,但是效率就很低下,因?yàn)榧词辜恿怂饕?,而在你?lián)合查詢 的時候語句寫的不當(dāng)就會導(dǎo)致索引不生效,從而效率就會下降。
1并不是所有索引對查詢都有效,SQL是根據(jù)表中數(shù)據(jù)來進(jìn)行查詢優(yōu)化的,當(dāng)索引列有大量數(shù)據(jù)重復(fù)時,SQL查詢可能不會去利用索引,如一表中有字段sex,male、female幾乎各一半,那么即使在sex上建了索引也對查詢效率起不了作用。
首先,安裝程序會顯示一個啟動畫面。如果使用的是不同的安裝盤,也許Readme文件的格式可能有所不同,但是不影響應(yīng)用程序的安裝。在上面的對話框中可以直接單擊對話框上的【下一步】按鈕,進(jìn)入下面的操作。
解決大量數(shù)據(jù),要么你OOP特別強(qiáng),寫的非常合理,老話:內(nèi)聚高,耦合低;要么就化整為零。本來PHP就不太適合處理特別大的數(shù)據(jù)。本身程序的健壯性就沒其他語言強(qiáng)。
我的思路是這樣:除了數(shù)據(jù)文本db.txt外,另建一個文本counter.txt用于記錄訪問的次數(shù)n。當(dāng)?shù)谝粋€用訪問時,程序先將counter.txt改為counter.lock,然后將里邊n=n+1,再改回原來的名字。并開始訪問相應(yīng)的n*50條記錄。
2在新建臨時表時,如果一次性插入數(shù)據(jù)量很大,那么可以使用 select into 代替 create table,避免造成大量 log ,以提高速度;如果數(shù)據(jù)量不大,為了緩和系統(tǒng)表的資源,應(yīng)先create table,然后insert。
顯示數(shù)據(jù)取出部分?jǐn)?shù)據(jù)的方法最常用的是分頁方式,分頁是僅讀取前面的幾十頁信息,讀取數(shù)據(jù)庫是很快的,可以比較一下10條和100條的顯示速度,差很遠(yuǎn)。
你的查詢需求中,最常用的where字段是什么,然后在數(shù)據(jù)表中給這個字段建立索引。多表查詢、嵌套查詢的話,就得優(yōu)化sql了,這個得具體情況具體分析了。
要分層次顯示,另外碰到數(shù)據(jù)庫查詢文字非常多的你還可以使用AJAX 返回?cái)?shù)據(jù) 這樣HTML就可以很快的顯示 顯示完畢才去讀數(shù)據(jù)庫這樣速度會快很多。至于樓上說的 緩存 數(shù)據(jù)庫存儲過程 可以參考一下,不過一般企業(yè)站不需要考慮。
避免使用!=或<>、IS NULL或IS NOT NULL、IN ,NOT IN等這樣的操作符。優(yōu)化SQL語句(讓SQL語句更合理一些)。優(yōu)化數(shù)據(jù)庫字段類型。(能用其他的盡量不要用VCHAR)建立儲存過程。
打開my.ini,如果是Linux服務(wù)器,那就是my.conf;然后在[mysqld]選項(xiàng)下面添加:skip-name-resolve 這個選項(xiàng)的意思是:禁用DNS解析,連接速度會快很多。
新聞名稱:php查詢上萬條數(shù)據(jù) 用php查詢數(shù)據(jù)庫信息
文章路徑:http://chinadenli.net/article40/deohcho.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、移動網(wǎng)站建設(shè)、用戶體驗(yàn)、網(wǎng)站排名、全網(wǎng)營銷推廣、品牌網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)