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