דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. תכנון מסד נתונים

תכנון מסד נתונים

מתוזמן נעוץ נעול הועבר תכנות
20 פוסטים 7 כותבים 1.1k צפיות 5 עוקבים
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
תגובה
  • תגובה כנושא
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • upsilon01U מנותק
    upsilon01U מנותק
    upsilon01
    כתב ב נערך לאחרונה על ידי upsilon01
    #5

    @מנצפך

    פתרון קצת יותר מסובך:
    בטבלה של המוצרים תוסיף עמודה של version לדוגמא:

    id | version | name | price  | size | enabled |
    -----------------------------------------------
    101| 01      | abc  | 100    |  15  |  false
    101| 02      | def  | 150    |  30  |  true
    

    כל פעם שיש עריכה של המוצר תשנה את enabled ל false
    ותיצור רשומה חדשה עם version +1 ו enabled = true

    ובטבלת הקניות תוסיף את הערך של version

    כשתרצה להציג את רשימת המוצרים תסנן לפי הערך של enabled

    מנצפךמ תגובה 1 תגובה אחרונה
    2
    • מנצפךמ מנצפך

      יש לי טבלת מוצרים וטבלת רכישות.
      בכל רכישה מצוין איזה מוצר נרכש (לפי ID של המוצר).

      הבעיה היא מה קורה שכשמשנים את פרטי המוצר, כולל מחיר שם ואפילו מהות (נניח מוצר וירטואלי של ספק אינטרנט, שאפשר לשנות אותו מ 15 MB ל 30 MB).

      מה שקורה שאחרי שיש שינוי כזה אי אפשר לעבד את הנתונים (נניח לבדוק מהו המוצר הכי פופולרי).

      מה כדאי לעשות? אולי בכל רכישה להוסיף את כל הנתונים של המוצר?

      ח מנותק
      ח מנותק
      חבלזון
      כתב ב נערך לאחרונה על ידי חבלזון
      #6

      @מנצפך אם השתנתה המהות - מדוע אתה קורא לזה "אותו מוצר"?
      מדוע להשתמש באותו ID?
      אם זה בשביל המחקר העתידי (מוצרים פופולריים), אפשר כמובן להוסיף "קטגוריה" וכדו'

      upsilon01U תגובה 1 תגובה אחרונה
      0
      • ח חבלזון

        @מנצפך אם השתנתה המהות - מדוע אתה קורא לזה "אותו מוצר"?
        מדוע להשתמש באותו ID?
        אם זה בשביל המחקר העתידי (מוצרים פופולריים), אפשר כמובן להוסיף "קטגוריה" וכדו'

        upsilon01U מנותק
        upsilon01U מנותק
        upsilon01
        כתב ב נערך לאחרונה על ידי
        #7

        @חבלזון
        לדוגמא אם אתה מפתח מערכת לחנויות ובעל החנות עורך את פרטי המוצר
        אז ה id נשאר אותו הדבר

        תגובה 1 תגובה אחרונה
        0
        • chagoldC מנותק
          chagoldC מנותק
          chagold
          כתב ב נערך לאחרונה על ידי
          #8

          גם אצל בעל החנות לא אמור להיות מוצרים משתנים. וכמו שאמרו כל מוצר יש לו את המהות שלו ואי"צ לגדיר מהות מוצר (לאותו ID) יותר מפעם אחת

          upsilon01U תגובה 1 תגובה אחרונה
          0
          • chagoldC chagold

            גם אצל בעל החנות לא אמור להיות מוצרים משתנים. וכמו שאמרו כל מוצר יש לו את המהות שלו ואי"צ לגדיר מהות מוצר (לאותו ID) יותר מפעם אחת

            upsilon01U מנותק
            upsilon01U מנותק
            upsilon01
            כתב ב נערך לאחרונה על ידי
            #9

            @chagold
            כשהמוצר הוא שירות אז הפרטים כן משתנים

            chagoldC תגובה 1 תגובה אחרונה
            2
            • upsilon01U upsilon01

              @chagold
              כשהמוצר הוא שירות אז הפרטים כן משתנים

              chagoldC מנותק
              chagoldC מנותק
              chagold
              כתב ב נערך לאחרונה על ידי
              #10

              @upsilon01 אמר בתכנון מסד נתונים:

              @chagold
              כשהמוצר הוא שירות אז הפרטים כן משתנים

              צודק.
              אבל נר"ל שא"כ עדיף לעשות טבלה נפרדת לversion's (וודאי שלא להחזיק באותה טבלה ID כפול).

              upsilon01U תגובה 1 תגובה אחרונה
              0
              • upsilon01U upsilon01

                @מנצפך

                פתרון קצת יותר מסובך:
                בטבלה של המוצרים תוסיף עמודה של version לדוגמא:

                id | version | name | price  | size | enabled |
                -----------------------------------------------
                101| 01      | abc  | 100    |  15  |  false
                101| 02      | def  | 150    |  30  |  true
                

                כל פעם שיש עריכה של המוצר תשנה את enabled ל false
                ותיצור רשומה חדשה עם version +1 ו enabled = true

                ובטבלת הקניות תוסיף את הערך של version

                כשתרצה להציג את רשימת המוצרים תסנן לפי הערך של enabled

                מנצפךמ מנותק
                מנצפךמ מנותק
                מנצפך
                כתב ב נערך לאחרונה על ידי
                #11

                @upsilon01 אמר בתכנון מסד נתונים:

                בטבלה של המוצרים תוסיף עמודה של version לדוגמא:

                רעיון מעניין, רק שזה מסרבל את הרשומה וגורם לכפילות נתונים.

                תגובה 1 תגובה אחרונה
                0
                • מנצפךמ מנותק
                  מנצפךמ מנותק
                  מנצפך
                  כתב ב נערך לאחרונה על ידי מנצפך
                  #12

                  המוצר הוא: זמן.
                  ולכן יכול להשתנות בין 30 דקות ל 35 דקות, נניח.
                  ואין זה מהות אחרת.

                  אני יכול לא לאפשר עריכת מוצר.
                  זו דווקא אפשרות שלא נראית לי הזויה בכלל.

                  השינויים לא מתבצעים בתדירות גבוהה, אם בכלל.

                  clickoneC תגובה 1 תגובה אחרונה
                  0
                  • chagoldC chagold

                    @upsilon01 אמר בתכנון מסד נתונים:

                    @chagold
                    כשהמוצר הוא שירות אז הפרטים כן משתנים

                    צודק.
                    אבל נר"ל שא"כ עדיף לעשות טבלה נפרדת לversion's (וודאי שלא להחזיק באותה טבלה ID כפול).

                    upsilon01U מנותק
                    upsilon01U מנותק
                    upsilon01
                    כתב ב נערך לאחרונה על ידי
                    #13

                    @chagold לא הבנתי איך

                    chagoldC תגובה 1 תגובה אחרונה
                    0
                    • upsilon01U upsilon01

                      @chagold לא הבנתי איך

                      chagoldC מנותק
                      chagoldC מנותק
                      chagold
                      כתב ב נערך לאחרונה על ידי chagold
                      #14

                      @upsilon01 אמר בתכנון מסד נתונים:

                      @chagold לא הבנתי איך

                      (לא הבנתי מה כוונת @מנצפך על זמן, אז אני עונה רק על מה שכתבתי לפני כן)

                      לעשות טבלה שתעסוק בגרסאות מוצרים, ויהיה שם שדה ID של מוצר ועוד שדה של מס' גרסה. (ועוד מס' שדות לפי הנתונים הדינמיים).
                      ותמיד כשיגשו למוצרים יהיה אפשר להעלות את כל הגרסאות עם JOIN.
                      (ואפשר לעשות שבטבלת מוצרים יהיה ג"כ שדה של 'מס' גרסה נוכחית' דהיינו שיכיל id של השדה המתאים מטבלת הגרסאות (ולייבא אותם תמיד עם join), וכך יהיה אפשר להחזיק גרסה נוכחית של כל מוצר)

                      תגובה 1 תגובה אחרונה
                      0
                      • מנצפךמ מנצפך

                        המוצר הוא: זמן.
                        ולכן יכול להשתנות בין 30 דקות ל 35 דקות, נניח.
                        ואין זה מהות אחרת.

                        אני יכול לא לאפשר עריכת מוצר.
                        זו דווקא אפשרות שלא נראית לי הזויה בכלל.

                        השינויים לא מתבצעים בתדירות גבוהה, אם בכלל.

                        clickoneC מנותק
                        clickoneC מנותק
                        clickone
                        כתב ב נערך לאחרונה על ידי
                        #15

                        @מנצפך
                        תעשה מוצר שנקראת דקת עבודה (לפי חישוב יחסי)
                        ובכמות תשים לפי מספר הדקות.
                        בכלל, כמות + סכום ליחידה + סכום כולל (אם יש) חייב להישמר בDB בכל עסקה מחדש.
                        אף פעם אל תסמוך על הגדרות המוצר בזה.

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

                        אין טסט כמו פרודקשן.

                        המייל שלי urivpn@gmail.com

                        מנצפךמ תגובה 1 תגובה אחרונה
                        3
                        • clickoneC clickone

                          @מנצפך
                          תעשה מוצר שנקראת דקת עבודה (לפי חישוב יחסי)
                          ובכמות תשים לפי מספר הדקות.
                          בכלל, כמות + סכום ליחידה + סכום כולל (אם יש) חייב להישמר בDB בכל עסקה מחדש.
                          אף פעם אל תסמוך על הגדרות המוצר בזה.

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

                          מנצפךמ מנותק
                          מנצפךמ מנותק
                          מנצפך
                          כתב ב נערך לאחרונה על ידי
                          #16

                          @clickone אמר בתכנון מסד נתונים:

                          תעשה מוצר שנקראת דקת עבודה (לפי חישוב יחסי)
                          ובכמות תשים לפי מספר הדקות.

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

                          clickoneC תגובה 1 תגובה אחרונה
                          0
                          • מנצפךמ מנצפך

                            @clickone אמר בתכנון מסד נתונים:

                            תעשה מוצר שנקראת דקת עבודה (לפי חישוב יחסי)
                            ובכמות תשים לפי מספר הדקות.

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

                            clickoneC מנותק
                            clickoneC מנותק
                            clickone
                            כתב ב נערך לאחרונה על ידי
                            #17

                            @מנצפך למה?
                            זה נחשב מוצר אחר
                            לדוגמא:

                            • דקת פיתוח = 3 ש"ח
                            • דקת תמיכה 1 ש"ח
                            • דקת שיחה 20 אג'

                            זה 3 מוצרים שונים.
                            בכל אחד אתה מכפיל בכמות את מספר הדקות

                            וזה לא מונע ממך לחשב כמה שעות היה בפועל לפיתוח, תמיכה וכו'

                            אין טסט כמו פרודקשן.

                            המייל שלי urivpn@gmail.com

                            תגובה 1 תגובה אחרונה
                            1
                            • upsilon01U מנותק
                              upsilon01U מנותק
                              upsilon01
                              כתב ב נערך לאחרונה על ידי
                              #18

                              אבל נותן השרות מוכר חבילות של דקות במחיר משתנה

                              דקת פיתוח = 1 שח
                              15 דקות = 6 שח
                              שעה = 15 שח

                              WWWW תגובה 1 תגובה אחרונה
                              1
                              • upsilon01U upsilon01

                                אבל נותן השרות מוכר חבילות של דקות במחיר משתנה

                                דקת פיתוח = 1 שח
                                15 דקות = 6 שח
                                שעה = 15 שח

                                WWWW מנותק
                                WWWW מנותק
                                WWW
                                כתב ב נערך לאחרונה על ידי
                                #19

                                @upsilon01 אז עושים הנחה.
                                כמו במכולת 3 ב 10 🙂

                                WWW.netfree@gmail.com || קשבק! החזר כספי לבנק על רכישות באינטרנט || עונים על סקרים ומרוויחים כסף!

                                upsilon01U תגובה 1 תגובה אחרונה
                                1
                                • WWWW WWW

                                  @upsilon01 אז עושים הנחה.
                                  כמו במכולת 3 ב 10 🙂

                                  upsilon01U מנותק
                                  upsilon01U מנותק
                                  upsilon01
                                  כתב ב נערך לאחרונה על ידי
                                  #20

                                  @www
                                  ואז צריך להחזיק טבלה של הנחות

                                  מבחינת לוגיקה יהיה נכון יותר
                                  אבל מבחינת ביצועים ככל שיש פחות קשרים בין טבלאות כך טוב יותר

                                  תגובה 1 תגובה אחרונה
                                  2
                                  תגובה
                                  • תגובה כנושא
                                  התחברו כדי לפרסם תגובה
                                  • מהישן לחדש
                                  • מהחדש לישן
                                  • הכי הרבה הצבעות


                                  בא תתחבר לדף היומי!
                                  • התחברות

                                  • אין לך חשבון עדיין? הרשמה

                                  • התחברו או הירשמו כדי לחפש.
                                  • פוסט ראשון
                                    פוסט אחרון
                                  0
                                  • דף הבית
                                  • קטגוריות
                                  • פוסטים אחרונים
                                  • משתמשים
                                  • חיפוש
                                  • חוקי הפורום