Drupal7 非常強大,其強大核心之一是entity field模式,比如node/taxonomy term/ user 都是一種entity, 并且支持field模式,也就是用戶可以隨意的添加新的field給node/taxonomy term/user;
強大的背后是性能的擔憂;加入node有10個field,那么就對應10個表來裝載field數據,而不是一個列,這就導致了至少10個join 去查詢一個node. 這對數據庫的性能影響是巨大,甚至是致命的;試想,如果一個頁面有10個block, 每個block包含10個node, 每個node有10個field, 那么查詢表的次數就是10次(使用entity_load_multiple),join的次數是100次;
我們幾乎沒有直接的辦法解決這個問題,畢竟這就是Drupal.
在這里我們提供一個小的性能優化辦法,即使用drupal_static函數,這個優化方法是PHP級別的,需要了解基本的PHP知識。
這個函數可以緩存函數執行結果,保證在函數執行退出后,結果存在內存中,但是又不同于memcache,它在一個請求結束后就自動釋放。
這里舉個例子:
現在有這樣子的需求,頁面上有2個block: last_news block, last_comment block,內容要求是last_comment 需要10條,首先取last_news 的comment, 如果不足,則按照時間先后順序取出除了和last_news comment 匹配的項;
分析下,last_news block保護了last_news 數據,在last_comment 也需要這個數據,假設有方法叫: news_last_news_data() 返回這個last_news,
函數原型:
新聞熱點
疑難解答