從sql本身來看,基本上沒有優(yōu)化的余地了,如果數(shù)據(jù)量過大造成的緩慢,
創(chuàng)新互聯(lián)是一家專業(yè)提供溆浦企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、HTML5建站、小程序制作等業(yè)務。10年已為溆浦眾多企業(yè)、政府機構(gòu)等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。
可以考慮使用sql分頁語句:
(即分頁由sql完成,并不是由PHP完成)
你要告訴我用的是什么數(shù)據(jù)庫: mysql? mssql? oracle?
如果不用sql分頁語句去寫,只能從數(shù)據(jù)庫上工夫。
1. 將幾個table 的 hotelId 字段, name字段 分別建立索引。
2. 建立分表,將大數(shù)據(jù)分之。
1.在可以用file_get_contents替代file、fopen、feof、fgets等系列方法的情況下,盡量用 file_get_contents,因為他的效率高得多!但是要注意file_get_contents在打開一個URL文件時候的PHP版本問題;
2.盡量的少進行文件操作,雖然PHP的文件操作效率也不低的;
3.優(yōu)化Select SQL語句,在可能的情況下盡量少的進行Insert、Update操作(在update上,我被惡批過);
4.盡可能的使用PHP內(nèi)部函數(shù)(但是我卻為了找個PHP里面不存在的函數(shù),浪費了本可以寫出一個自定義函數(shù)的時間,經(jīng)驗問題啊!);
5.循環(huán)內(nèi)部不要聲明變量,尤其是大變量:對象(這好像不只是PHP里面要注意的問題吧?);
6.多維數(shù)組盡量不要循環(huán)嵌套賦值;
7.在可以用PHP內(nèi)部字符串操作函數(shù)的情況下,不要用正則表達式;
8.foreach效率更高,盡量用foreach代替while和for循環(huán);
9.用單引號替代雙引號引用字符串;
10.“用i =1代替i=i 1。符合c/c 的習慣,效率還高”;
11.對global變量,應該用完就unset()掉
最好是把判斷的語句寫在SQL里面,一般從一個表或視圖查詢數(shù)據(jù)插入另外表的語句是:
insert into new_tab select * from old_tab;
同時加上判斷條件的語句是:
insert into new_tab select * from old_tab where ....;
你的語句是正確的,速度慢兩種可能:
一、是索引不對,你所有的關(guān)聯(lián)字段,應該在相應表中有唯一索引,最好是主鍵,例如:
cdb_members.uid
cdb_memberfields .uid
supe_userfields.uid
cdb_members.groupid
cdb_usergroups.groupid
supe_userspaces.uid
supe_userspacefields.uid
如果以上的表沒有主鍵,請設(shè)置相應字段為主鍵,如果有其他的主鍵而且是必須的,那么在上面的字段建立唯一索引。
二、數(shù)據(jù)量過大,如果你cdb_members的記錄很多,遠遠大于500條,可以考慮改變程序,先重此表里面獲取500條數(shù)據(jù),然后在循環(huán)里面每條數(shù)據(jù)庫關(guān)聯(lián)獲取其它表的信息,這樣就不需要先對五個表做鏈接。