[MANUAL] English:
[zend.git] / documentation / manual / he / ref / performance-database.xml
blob9182ec418ac99543e7630f31f3d250f29db3b58c
1 <sect1 id="performance.database">
2     <title>Zend_Db שימוש נכון למיטב הביצועים</title>
4     <para>
5         <code>Zend_Db</code> הינה בסיס שכבות למחלקות אשר מטפלות במסדי נתונים, ונועדה
6         כדי לתת API נפוץ לפעולות אשר נעשות על גבי ה SQL. <code>Zend_Db_Table</code>
7         הינה מחלקת מידע לניתוב טבלאות מסדי נתונים, אשר מהוות בתור מחלקה כשכבה עליונה לכל המחלקות אשר נמצאות
8         תחתיה, שנועדו למטרת ביצוע פעולות טבלאויות מול מסד הנתונים.
9         מאחר ואלו מחלקות שאר מהוות שכבה עליונה לכל המחלקות תחתיהם, "והקסם" שהם מבצעות ברקע כדי לבצע את הפעולות שלהם,
10         הם לעתים יכולים לגרום לבעיות משמעותיות בביצועים של המערכת.
11     </para>
13     <sect2 id="performance.database.tableMetadata">
14         <title>אין ניתן להפחית את כמות המשאבים שצורכת המחלקה של Zend_Db_Table
15                בזמן שליפת נתונים אודות טבלה/טבלאות?</title>
17         <para>
18             כדי לייעל ולפשט את השימוש כמה שניתן, ועדיין לתמוך בתרשים מסד הנתונים גם כשהוא משתנה תוך כדי פיתוח,
19             <code>Zend_Db_Table</code> מבצעת מספר דברים מאחורי הקלעים: בשימוש הראשון,
20             היא שולפת את כל התרשים של מסד הנתונים ושומרת את זה באובייקט מסויים לשימוש חוזר. פעולה זו היא בדרך כלל צורכת הרבה משאבים ויכולה לגרום
21             לצוואר בקבוק במערכות, ולא משנה באיזה מסד נתונים משתמשים.
22         </para>
24         <para>
25             למרבה המזל ישנם טכניקות שונות לשיפור התפעול במצבים כאלו.
26         </para>
28         <sect3 id="performance.database.tableMetadata.cache">
29             <title>שימוש במטמון אודות הנתונים של המסד</title>
31             <para>
32                 <code>Zend_Db_Table</code> יכולה להשתמש ב <code>Zend_Cache</code> כדי לשמור את הנתונים אודות התרשים של מסד הנתונים שנשלף במטמון.
33                  בדרך זו יהיה מהיר יותר לגשת לנתונים ולצרוך פחות משאבים בכל פעם שמנסים לגשת לנתונים אודות מסד הנתונים שנשלפו.
34             </para>
36             <para>
37                 הדוקומנטציה של <link linkend="zend.db.table.metadata.caching"><code>Zend_Db_Table</code>
38                 מכילה מידע אודות שימוש במטמון במחלקה זו.</link>.
39             </para>
40         </sect3>
42         <sect3 id="performance.database.tableMetadata.hardcoding">
43             <title>כתיבה ידנית של המידע אודות הטבלה בהגדרות של אותה טבלה</title>
45             <para>
46                 מאז גרסא 1.7.0, <code>Zend_Db_Table</code> מאפשר תמיכה ב <link
47                     linkend="zend.db.table.metadata.caching.hardcoding">כתיבה ידנית של המידע אודות הטבלה בהגדרות של אותה טבלה</link>.
48                 זהו שימוש מתקדם יותר, ורצוי להשתמש בו רק כשתרשים הטבלה ידוע מראש וסביר להניח שהוא לא השתנה מאוחר יותר, או שתוכלו להמשיך ולעדכן את ההגדרות של הטבלה בכל פעם שתרשים הטבלה השתנה.
49             </para>
50         </sect3>
51     </sect2>
53     <sect2 id="performance.database.select">
54         <title>פקודות SQL אשר נוצרו בעזרת Zend_Db_Select לא משתמשות באינדקסים של הטבלה; כיצד ניתן לשפר זאת?</title>
56         <para>
57             <code>Zend_Db_Select</code> בהחלט עושה עבודה טובה במה שהוא אמור לעשות.
58              אך למרות זאת, במידה והנכם מבצעים שאילתות מסובכות למסד הנתונים אשר מכילות חיבורים בין טבלאות ותתי שאילתות, זה יכול להיות לפעמים תמים בנושא זה.
59         </para>
61         <sect3 id="performance.database.select.writeyourown">
62             <title>כתבו את פונקציות השליפה כנגד מסד הנתונים בעצמכם</title>
64             <para>
65                 התשובה האמיתית היחידה היא כתיבת פונקציות שליפת הנתונים שלכם בעצמכם;
66                 <code>Zend_Db</code> לא מחייב שימוש ב <code>Zend_Db_Select</code>, לכן כתיבת שאילות שליפת הנתונים שלכם בעצמכם היא בהחלט גישה תקינה,
67             </para>
68             <para>
69                 הריצו את פקודת ה <code>EXPLAIN</code> על גבי השאילתות שלכם על מנת לבדוק כמה וכמה גישות
70                 עד שתוכלו להגיע לשאילתה עם התוצאות הטובות ביותר.
71             </para>
73             <para>
74                 אם השאילתה דורשת הזנה של משתנים בתור נתונים, השתמשו ב"שומרי מקום" בשאילתות, והשתמשו בשילוב של
75                 <code>vsprintf</code> ו <code>array_walk</code> כדי להזין את אותם המשתנים אל השאילתות.
76                 לדוגמא:
77             </para>
79             <programlisting role="php"><![CDATA[
80 // $adapter is the DB adapter. In Zend_Db_Table, retrieve
81 // it using $this->getAdapter().
82 $sql = vsprintf(
83     self::SELECT_FOO,
84     array_walk($values, array($adapter, 'quoteInto'))
86 ]]></programlisting>
87         </sect3>
88     </sect2>
89 </sect1>
90 <!--
91 vim:se ts=4 sw=4 et:
92 -->