php導出大量數(shù)據(jù)到Excel,可以通過生成多個Excel文件,然后壓縮成壓縮包解決。
創(chuàng)新互聯(lián)作為成都網(wǎng)站建設公司,專注成都網(wǎng)站建設公司、網(wǎng)站設計,有關(guān)成都企業(yè)網(wǎng)站定制方案、改版、費用等問題,行業(yè)涉及成都宣傳片制作等多個領域,已為上千家企業(yè)服務,得到了客戶的尊重與認可。
方案是:假如我們數(shù)據(jù)庫有10w條數(shù)據(jù),每2000條數(shù)據(jù)生成一個Excel文件,這樣每次只要從數(shù)據(jù)庫里查詢出2000條數(shù)據(jù)即可,一定要分頁去查詢。
原因:主要是數(shù)據(jù)庫性能和寫文件性能。分頁查詢可以解決數(shù)據(jù)庫壓力的問題, 生成多個文件可以解決單個文件太大,后期維護Excel文件的問題。
要注意的:
1. 在導出邏輯文件開頭,一定要聲明 set_time_limit(0) ,防止腳本超時;
2. 每個文件生成后,適當?shù)膕leep一下,讓程序休息一下下;
3. 因為一次導出最后要將生成的多個Excel文件打包成一個壓縮包,所以要刪除掉生成的Excel文件,節(jié)省服務器存儲空間;
下面是我實際工作中,寫的一個php導出大量數(shù)據(jù)到Excel的代碼,你可以參考一下:
沒環(huán)境是不能運行項目的,你要先安裝環(huán)境,才能運行。
至于打包,你只要把項目文件打包,還有把相應數(shù)據(jù)庫導出成.sql文件。
在新環(huán)境把項目文件放到對應web目錄,把.sql文件導回到新數(shù)據(jù)庫,最后不要忘了在新環(huán)境的項目要修改新的數(shù)據(jù)庫連接帳號密碼。
1關(guān)于PHP打包
把PHP解釋器和PHP項目打包成一個安裝包完全沒有問題的,我甚至把PHP解釋器打包到Android手機上跑都沒問題.因為PHP官方提供了Windows版本的二進制包,所以連自己編譯這一步都省了,為了精簡PHP解釋器,你可以把你不需要的擴展都刪除掉,比如intl擴展及其依賴的ICU,精簡后打包估計解釋器能小于5個MB.因為PHP內(nèi)置了HTTP服務器和SQLite數(shù)據(jù)庫,所以客戶端連Apache和MySQL也不依賴了,直接就能跑PHP項目,而且還省資源.
2.關(guān)于PHP代碼保護
PHP7的opcache支持用opcache.file_cache導出PHP腳本對應的二進制opcode,這些opcode是跟操作系統(tǒng)和PHP解釋器版本相關(guān)的,能起到一定的代碼保護的作用.另外,Zend
Guard和ionCube也提供了付費的PHP代碼加密服務.
3.授權(quán)
比如可以在加密過的PHP代碼里判斷$_SERVER['SERVER_NAME'],如果不是授權(quán)時綁定的域名,就直接拒絕服務.如果還有什么不懂不明白的,你可以和我在后盾人看看教材找找答案,時間久了,就都清楚了,希望能幫到你
首先把數(shù)據(jù)庫導出成sql文件(可以使用phpmyadmin導出,也可以使用mysqldump, 命令為mysqldump -uxxx -pxxx 數(shù)據(jù)庫名 文件名.sql),放在/(也有可能是其它目錄)下面,然后整個打包
估計你的目的是遷移
再次移出后,把數(shù)據(jù)導入新的數(shù)據(jù)庫,上傳文件,并設定權(quán)限(如果是租用的空間就沒必要了,因為運行apache的帳號擁有此權(quán)限,設置配置文件(如果有的話,沒有你就只能改原文件了)
接下來就是可能的問題的處理
至此,完成