1. 不要使用 mysql_ 類函數
終于,你不用再看到建議不要使用 mysql_
函數的提示了。因為 PHP 7 從核心上完全移除了它們,這意味著請你移步至更好的 mysqli_
類函數,或者更靈活的 PDO 層。
2. 不要寫無用的代碼
這看上去是個無腦建議,但是隨著 PHP7 速度的提升掩蓋了一些問題使它顯得日趨重要。不要僅僅因切到 PHP7 讓網站速度變得快點,你就沾沾自喜了。
想理解速度的重要性和如何做的更好,去看看我們這篇文章 初學者加速優化指南。
作為開發者,應該確保按需加載腳本,可能時再組合,編寫高效的數據庫查詢語句,如果可能的話 使用緩存 等等。
3. 不要在文件末尾使用 PHP 閉合標簽
如果你隨便看看,就會發現大部分 WordPress 核心代碼文件結尾都省略了 PHP 閉合標簽。事實上,Zend 框架尤為明顯地 禁止了閉合標簽。它并非 PHP 所必須,在文件結尾處省略它,可確保結尾無額外空白。
4. 如非必須不要引用傳參
我個人非常不喜歡引用傳參。我當然知道在某些場合下它很有用,但是多數場合下,它會使得代碼難以理解,難以遵循,難以預測結果。
人們認為引用可以使它們的代碼更快,不過正如 可敬的 PHP 程序員 的這篇文章所指出的,事實并非如此。
PHP 內置的 shuffle()
或者 sort()
函數,就是糟糕的引用傳參案例。 它修改了原數組而不是返回一個打亂的或者排好序的數組,這是完全違背了我們意愿的。
5. 不要在循環里使用查詢
在循環中使用數據庫查詢時最糟糕的。他會給系統帶來不必要的壓力,并且很有可能,你可以在循環外使用查詢而更快的得到相同的結果。當我碰到必須這樣用的場景時,我通常會通過分成兩個查詢來構造一個數組的方式來解決。然后循環數組而無需循環查詢。
由于 WordPress 的運行方式,這樣做可能會有些例外。 get_post_meta()
將從數據庫獲取一個元數據,如果您正在循環訪問特定文章的元數據,則可以在循環中使用它。這是因為當你第一次使用它的時候,WordPress 實際上取得了所有的元數據并緩存了起來。 之后的調用實際上是調用緩存數據而不是調用數據庫。
解決這些問題的最好辦法是閱讀函數文檔并且使用一些類似 查詢監聽器 的東西。
6. 不要在 SQL 查詢中使用 *
好吧,這更像是一個 MySQL 的問題,但我們更傾向于在代碼中編寫 SQL 語句,所以我說這是個公平的游戲。不管什么情況下,如果你能避免使用通配符,那就不要使用,尤其是當你的數據庫有很多字段的時候。
明確指定你需要的字段,并且只檢索這些字段。這有助于節省內存,保護數據,并且能讓事情變得更加清晰明白。
在 SQL 方面,盡可能的了解你可用的函數并測試速度。 當計算平均數,求和以及計算相似的數字的時候,使用 SQL 內置函數而不是 PHP 的函數。 如果你不確定一個查詢的速度快慢,測試一下它并和其他做法進行比較,選出最好的那一種。
7. 不要信任用戶的輸入
信任用戶輸入并不明智。對于用戶輸入,總是需要過濾,殺毒,轉義,校驗以及使用回退。 用戶輸入存在三個問題:我們開發者不可能考慮到所有可能性,經常出錯,存心的惡意輸入。
一個經過深思熟慮的系統可以防止所有的這些問題。 在使用數據庫時,確保使用內置的函數,如 filter_var()
,來檢查合法性,進行轉義,和其他能做的事。
WordPress 有一堆函數可以幫到你。可以瞧一瞧這篇文章來了解