שימוש ב-Static Var למטרת caching

לכבוד השנה החדשה, הנה טכניקה נחמדה ב-PHP שכדאי להכיר אותה. הטכניקה הזו עוזרת בכתיבת קוד יעיל יותר.

בואו ונניח שיש לי פונקציה שמבצע קריאה ל-MySQL – כדי לבדוק הרשאות לצורך העניין:



function callToMySQL() {

//Some MySQL Call
$result = mysql_query('SELECT * FROM my_costumer');

return $result;
}

אם אני קורא לפונקציה (או מתודה, אבל בואו נשאר בפרוצדורלי לשם הדוגמה) הזו רק פעם אחת – הכל סבבה. אבל אם אני קורא לה כמה פעמים באותו דף? זה לא תסריט שהוא לא נפוץ. יש לנו לא מעט מקרים שבדף יש לנו מספר קריאות לפונקציה מסוימת שמבצעת קריאה ל-MySQL. לא תמיד מי שמבצע את הקריאה נמצא באותו קונטקסט עם מישהו אחר שמבצע את הקריאה. כך למשל אם יש לי שני מודלים שמשתמשים ב-API שמספק מודל אחר – זה בהחלט מצב שיכול לקרות.

כך הפונקציה יכולה לבצע מספר קריאות ל-MySQL. באופן עקרוני זה לא יפיל את האפליקציה שלכם, אבל למה שלא לשמור ב-cache את התוצאות של הקריאה ואם מישהו שוב יקרא לפונקציה בזמן שהסקריפט פעיל – היא תחזיר את התוצאות של הקריאה ל-MySQL במקום לבצע קריאה נוספת?

איך עושים את זה? באמצעות Static var – משתנה שנשמר "בזכרון" של הסקריפט כל עוד הוא רץ. הוא פג ברגע שהסקריפט מסתיים לרוץ אבל כל עוד הסקריפט רץ, כל מה שנכניס ל-static var יכנס לשם. למשל:


function callToMySQL() {

static $result = null;
if(!is_null($result))
     return $result;

//Some MySQL Call
$result = mysql_query('SELECT * FROM my_costumer');

return $result;
}

מה פה קורה פה? בקריאה הראשונה, המשתנה result מוגדר כמשתנה סטטי שיש בו null. בהמשך המשתנה נבדק – הוא מן הסתם null ולפיכך הקריאה למסד הנתונים מתבצעת ולתוך המשתנה נכנסת התוצאה. הסקריפט ממשיך לרוץ והדף עדיין בשלב הרינדור. אם יש קריאה נוספת, המשתנה result, כיוון שהוא סטטי, עדיין מכיל מידע והפונקציה מחזירה אותו ללא ביצוע קריאה למסד הנתונים וכך חסכנו בביצועים.

ומה קורה אם יש פרמטר? אין שום בעיה להגדיר מערך כמשתנה סטטי. למשל:


function callToMySQL($param) {

static $result = array();
if(isset($result[$param]))
     return $result[$param];

//Some MySQL Call
$result[$param] = mysql_query('SELECT * FROM my_costumer');

return $result[$param];
}

ובכך מוודאים שאין קריאות מיותרות ל-MySQL. כמובן שהקוד הנ"ל שימושי לא רק למניעת קריאות מיותרות למסד הנתונים אלא גם מחישובים מיותרים ולמגוון סיבות אחרות. ניתן להשתמש בזה גם בתכנות פרוצדורלי וגם בתכנות מונחה עצמים. פשוט, קל ואלגנטי.

כדאי תמיד להשאר מעודכנים! הרשמו לעדכונים של האתר במייל! - המייל יישלח כל יום ראשון בעשר בבוקר ויכיל אך ורק את המאמרים שהתפרסמו באינטרנט ישראל. ללא ספאם, ללא הצפות, ללא בלגנים. 🙂

אהבתם? לא אהבתם? דרגו!

לא אהבתי בכלללא אהבתיבסדראהבתיאהבתי מאוד (אין הצבעות)

תגיות: פורסם בקטגוריה: פתרונות ומאמרים על פיתוח אינטרנט

אל תשארו מאחור! יש עוד מה ללמוד!

הצטרפו לעדכונים!

העדכונים נשלחים אך ורק כאשר האתר מתעדכן.

רן בר-זיק

רן בר-זיק כותב כל המאמרים באינטרנט ישראל, מפתח אינטרנט מנוסה במגוון שפות ופלטפורמות.
ניתן ליצור איתי קשר באמצעות:
כתובת המייל שלי: info@internet-israel.com.
פרופיל הלינקדאין שלי
הטוויטר שלי
פרופיל הפייסבוק שלי
אני תמיד שמח לייעץ ולעזור, אך בשל עומס הפניות הרב, אני לא תמיד מצליח לענות במהירות.