發(fā)布時間:2021-09-01 14:48:54來源:轉(zhuǎn)載
PHP 能做很多事情。PHP 主要是用于服務端的腳本程序,因此可以用 PHP 來完成任何其它的 CGI 程序能夠完成的工作,例如收集表單數(shù)據(jù),生成動態(tài)網(wǎng)頁,或者發(fā)送/接收 Cookies。那么,PHP導出數(shù)據(jù)為什么有時會超時?
一般情況下,導出超時可能都是以下三種情況:
一、sql語句復雜,查詢時間過長;
二、處理查詢后數(shù)據(jù)邏輯冗余;
三、數(shù)據(jù)量過大導致響應超時。
優(yōu)化建議
一、sql語句復雜,查詢時間過長
1、查看索引是否設(shè)置妥當,即所用的查詢條件是否有添加索引,當然索引不是越多越好,只需給常用的查詢條件加上即可,一般采用B+樹的索引方式(具體原因可自行百度,不再贅述)
2、在查詢語句中盡量避免IN、NOT IN、IS NULL、OR、!=、<>、LIKE、OR、NOT EXISTS這些查詢條件的出現(xiàn),會導致索引失效。
IN查詢時,可以考慮用BETWEEN來代替
LIKE查詢時,僅當"%"在前時會索引失效,"%"在后是不會失效的
查詢條件里還要避免數(shù)字的出現(xiàn),使用字符串,數(shù)字也會導致索引失效,例如,查詢:"pid"=1,可以優(yōu)化為"pid"="1"
要盡量避免在循環(huán)中使用查詢語句,這種情況一般可以用join或者with來解決(當涉及到跨庫時,請謹慎使用這種方式!)
查詢時,可以指定需要查詢的字段,排除掉不需要的字段避免資源浪費
當數(shù)據(jù)量多大時,可以使用分頁和緩存來優(yōu)化(具體方法請參考數(shù)據(jù)量過大導致響應超時部分)
二、處理查詢后數(shù)據(jù)邏輯冗余
在做數(shù)組循環(huán)時,盡量使用continue、break來減少沒必要的循環(huán);
盡量減少if嵌套層數(shù),在需要用到多個if-else時,使用switch可以提率,特別是在數(shù)據(jù)量大時
三、數(shù)據(jù)量過大導致響應超時
當數(shù)量兩過大,又不想用異步的方式導出excel文件時,可以嘗試使用csv來作為到處格式,且查詢導出數(shù)據(jù)時可以使用分頁的方式查詢,導出時利用ob_flush進行緩存。
當數(shù)據(jù)訪問次數(shù)過多時,建議使用redis緩存一些固定數(shù)據(jù),減少mysql查詢次數(shù)。